

COMPUTER SYSTEM 

REFERENCE MANUAL 



CONTROL DATA 



CORPORATION 



3300 CHARACTERISTICS 

Stored- program, solid-state, scientific and business data processing computer 

Time- sharing and multiprogramming features 

Parallel mode of operation 

Diode logic 

Character and word addressing (4 characters per word) 

Address modification (indexing) 

Indirect addressing 

28-bit storage word (24 data bits and 4 parity bits) 

Nonvolatile magnetic core storage 

Complete cycle time: 1.25 microseconds 

Access time: 0. 75 microsecond 

Storage sharing 

Selected storage protection 

Instruction repertoire compatible with the 3100, 3200, and 3500 Computers 

Business oriented Moves, Searches, Edit, Compare, Conversion, and BCD 

arithmetic instructions 

Logical and sensing operations 

Masked storage searches 

Block control operations 

Trapped instruction processing 

2 4- bit accumulator register and auxiliary accumulator register 

Binary arithmetic: 224-1 modulus, one's complement for all single pre- 
cision (24-bit) operations and double precision (48-bit) addition and subtrac- 
tion 

64- word register file (0. 5 microsecond cycle time) 

Complete interrupt system 

ASCII to BCD conversion (and vice versa) and 4-bit/6-bit packing 

Real-time clock (1.0 millisecond incrementation) 

Sit-down operator's console featuring: On-line typewriter and complete 

display and control system 

Upward compatability with 3100 and 3200 computer systems 

Standard 3000 Series type 12-bit bidirectional data channel 

Compatible I/O mediums include magnetic tape, disk file, punched cards, 

paper tape, and printed forms 

Options include: 

Memory expansion to 2 62, 144 words (over 1 million characters) 

Additional 12-bit data channels or high-speed 24-bit data channels 

Floating point and 48-bit precision multiply and divide hardware logic 

Multiprogramming hardware module 

Business Data Processor 

Complete selection of advanced peripheral equipment 
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FORWARD 

This manual provides information for the machine language use of the 3 300 computer 
system. Its intention is to describe the capabilities and programming restraints of 
the hardware. 

COMPASS mnemonics are used to abbreviate titles of instructions; however, no software 
systems are used in describing instructions. Brief descriptions of these software 
systems are included in Section 6. Detailed descriptions for those systems in operation 
are available in the appropriate software reference manuals. 

Progranaming information for most available peripheral equipments is contained in the 
3000 Series Peripheral Equipment Reference Manual, Pub. No. 60108800. 
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CONTROL DATA 3300 COMPUTER SYSTEM 



1. GENERAL SYSTEMS DESCRIPTION 



INTRODUCTION 

The CONTROL DATA* 3300 is an advanced design general-purpose computing 
system providing high performance time- sharing with multiprogramming fea- 
tures to satisfy present and future needs of business and scientific users. Ad- 
vanced design techniques are used throughout the 3300 to provide expedient 
solutions for scientific, real-time, and business data processing problems. 

Time- sharing and multiprogramming features of the 3300 enable a user to 
enter many programs and receive processed results without the delays incurred 
in single- job batch processing systems. This feature not only reduces turn- 
around time but also provides a considerable saving in computer usage and 
personnel time. Multiprocessing of programs further enhances system perfor- 
mance when additional central processors are integrated into a total system. 



Software systems for the 3300 take full advantage of the time-sharing and 
multiprogramming capabilities of the hardware and include the MASTER, 
Real-Time SCOPE, and MSOS operating systems, and the Mass Storage 
Input/Output (MSIO) system. A synopsis of each of these systems and other 
software is included in Section 6 of this manual. 

All existing programs written for CONTROL DATA 3100 and 3200 systems can be 
processed by a 3300. I/O characteristics for the 3300 are identical to the 
3100, 3200, 3400, 3500, 3600, and 3800 line of Control Data computers - a fact 
which facilitates incorporating the 3300 into a SATELLITE* configuration. 

Included in the expanded repertoire of 3300 instructions is a complete list of 
business data processing instructions. These extend the flexibility of the 3300 
by performing field searches, moves, compares, tests, conversions, arithmetic 
operations, and complete COBOL editing while utilizing the time- sharing feature 
of the 3300. 

A wide selection of proven peripheral equipment is available for use in a 3300 
system including many new and advanced equipments. 



*Registered trademark of Control Data Corporation 
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This manual describes the various features of the 3300 and provides program- 
ming and operation information. Reference and supplementary information may 
be found in the Appendixes. 



COMPUTER MODULARITY 



A 3300 computer consists of various logic cabinet modules designed to perform 
specific operations. If additional storage, input/ output channels, or arithmetic 
capabilities are desired for an existing installation, an appropriate module is 
integrated into the system. Figure 1-1 illustrates and describes the modules 
of a typical 3300 computer. 




® Central Processing Unit (CPU) 

(g) 2-3306 Input/Output (I/O) 
channels or 1-3307 channel 
and 1-3306 channel (Channels 
and 1) 

© 2-3306 I/O channels or 1-3307 
channel and 1-33 06 channel 

© 2-3306 I/O channels or 1-3307 
channel and 1-3306 channel 



® 
(J) 



2-3306 I/O channels or 1-3307 
channel and 1-3306 channel 

Power controls for I/O channels 
©®(E) 

3310 Floating Point module 

3311 Multiprogramming module 
Power Control Panel for(S) (§) 
3309- 8K Storage Module 
3309- 8K Storage Module 



Figure 1-1. 3300 Modularity Example 

NOTES 

1. A minimum 3300 configuration consists of items @ , © , (T) , and (j) . 

2. A 3302 16K storage module may be substituted for items (J) and @ . 

(Cont'd on next page) 
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3. Additional storage modules are added to the left of item (g) . 

4. The 3312 BDP (not shown) is a "stand-alone" cable connected unit. Addi- 
tional storage modules may also be stand-alone units to conform to installa- 
tion space. 

5. 3307 I/O channels are always designated an even channel number, i. e. , 0, 2, 
4, or 6. 

Central Processing Unit 

The Central Processing Unit (CPU) is standard in all 3300 systems and performs 
the following functions: 

• Controls and synchronizes most internal operations of the computer. 

• Processes all 24-bit precision fixed point arithmetic. 

• Processes 48-bit precision addition and subtraction. 

• Executes Boolean instructions. 

• Character and word loading and storing. 

• Executes decision instructions. 

• Controls standard search and move operations, external equipment and 
typewriter I/O, real-time clock referencing, and register file operations. 

• Recognizes and processes all interrupts. 

If the Business Data Processor (BDP) is present in a system, the CPU relin- 
quishes control to it until the business oriented instructions(s) have been pro- 
cessed. 

Storage Modules 

The magnetic core storage (MCS) available for 3300 systems ranges from a min- 
imum of 8,192 (32,768 characters) to 262,144 (1,048,576 characters) words. An 
MCS system is expanded in 16,384 word increments after two initial 8,192 word 
storage modules are installed in the system. Up to 131,072 words of MCS may 
be included in a system without the multiprogramming option present. 

The following optional storage modules are available: 

Model 3309 - 8,192 word (32,768 characters) MCS memory module 
Model 3302 - 16,384 word (65,536 characters) MCS memory module 

The word "storage" is used synonymously with "memory" in this text and both 
refer to MCS unless otherwise stated. Additional information pertaining to the 
3300 storage system may be found in Section 2. 

Input/Output Modules 

Two types of Input/Output (I/O) modules are available for use in 3300 systems. 
These are the 3306 and 3307 Communication Channels. 

The 3306 is a bidirectional 12 -bit parallel data channel and conforms to the stand- 
ard I/O specifications for all CONTROL DATA 3000 Computers. A maximum of 
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eight 3306 channels may be incorporated in a single system with up to eight 
peripheral controllers connected to each channel. Space is provided for mount- 
ing two 3306 channels per module. Figure 1-1 shows the placement of the 
channels in a maximum I/O channel configuration. 

The 330 7 is a bidirectional 24-bit parallel data channel and also conforms to the 
Control Data 3000 I/O specification. In each 3307 channel 12-to 24-bit assembly/ 
disassembly is included. A maximum of four 3307 channels in addition to four 
3306 channels may be present in a single system. 

Additional information pertaining to the 3306 and 3307 I/O channels may be 
found in Section 3. 

Floating Point Module 

The optional 3310 Floating Point Module permits a user to directly execute 
floating point addition, subtraction, multiplication, and division instructions 
utilizing 48-bit precision floating point operands. This option also permits 
direct execution of 48-bit precision multiplication and division instructions. 

Multiprogramming Module 

The optional 3311 Multiprogramming Module provides capability to relocate 
program instructions, data, and I/O in MCS. This option implements the 3300 
memory page system and provides inherent memory protection as well as re- 
location and MCS extension to 262, 144 words. If the 3311 is not present in a 
system, the maximum number of words is 131,072. Refer to Appendix E for 
additional information. 

Business Data Processor 

The optional 3312 Business Data Processor (BDP) provides the capability to 
directly execute variable field length business data processing instructions. 
These instructions include field searches, moves, editing operations, compares, 
arithmetic operations, and binary/BCD/ASCII conversions. Delimiting is pro- 
vided for appropriate instructions to increase their flexibility. 

The internal organization of the BDP is further described under Internal Organi- 
zation in this section. 

Operator's Console 

The operators desk console includes: 
Octal register displays 
Built-in on-line typewriter 

Built-in entry keyboard and control switches 
Complete status monitoring system 
Operator's chair 
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A complete description of the console, examples of manual operations, and a 
picture of the console can be found in Section 7. 

PoAver Control Panel 

A power control panel is provided to control secondary logic power to the CPU, 
floating point module, and I/O channels and 1. Other modules have their own 
power control panels. Prinaary power for the entire computer system is con- 
trolled by a group of switch boxes mounted on a nearby wall. 



INTERNAL ORGANIZATION 

Central Processing Unit 

Computer Word Format 

The standard 3300 computer word consists of 24 binary digits. Each word is 
divided into four 6-bit characters. In storage, an odd parity bit is generated 
and checked for each of the four characters, lengthening the storage word to 
28 bits. Figure 1-2 illustrates the bit assignments of a computer word in 
storage. 



23 




18 17 


12 II 




06 05 




00 









1 


2 




3 



\ \ / / 

Character Designators 



Figure 1-2. Computer Word Character Positions and Bit Assignments 

Register Descriptions 

A Register (Arithmetic): The A register (accumulator) is the principal arith- 
metic register. Some of the more important functions of this register are: 

• Most arithmetic and logical operations use the A register in formu- 
lating a result. The A register is the only register with provisions 
for adding its contents to the contents of a storage location or 
another register. 

• The A register may be shifted to the right or left separately or 
in conjunction with the Q register. Right shifting is end-off; the 
lowest bits are discarded and the sign is extended. Left shifting 
is end-around; the highest order bit appears in the lowest order 
stage after each shift; all other bits move one place to the left. 

• The A register holds the word which conditions jump and search 
instructions. 

Q Register (Arithmetic ): The Q register is an auxiliary accumulator register 
and is generally used in conjunction with the A register. 
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The principal functions of Q are: 

• Providing temporary storage for the contents of A while A is used 
for another arithmetic operation. 

• Forming a double- length register, AQ. 

• Shifting to the right or left, separately or in conjunction with A. 

• Serving as a mask register for 06, 07, and 27 instructions. 

E Register (Arithmetic): The optional arithmetic register E is present in a 
system whenever the 3311 Floating Point option is present in a system. During 
floating point/ 48-bit precision operations, the E register is divided into two 
parts, Eu* and El*, each composed of 24 bits. It is used as follows: 

• 48-bit precision multiplication; holds the lower 48 bits of a 96 -bit 
product. 

• 48-bit precision division; initially holds the lower 48 bits of the 
dividend; upon completion, holds the remainder. 

• Floating point multiplication; holds the residue of the coefficient 
of the 48-bit product. 

• Floating point division; holds the rem.ainder. 

P Register (Main Control) : The P register is the Program Address Counter. 
It provides program continuity by generating in sequence the storage addresses 
which contain the individual instructions. During a Normal Exit the count in P 
is incremented by 1 at the completion of each instruction to specify the address 
of the next instruction. These addresses are sent via the S (address) Bus to the 
specified storage module where the instruction is read. A Skip Exit advances 
the count in P by 2, bypassing the next sequential instruction and executing the 
following one. For a Jump Exit, the execution address portion of the jump in- 
struction is entered into P and used to specify the starting address of a new 
sequence of instructions. 

B" Registers (Main Control) : The three index registers, B-*-, B^, and B , are 
used in a variety of ways, depending on the instruction. In a majority of the 
instructions they hold quantities to be added to the execution address, M=m+B . 
The index registers naay be incremented or decremented. 

C Register (Main Control) : Quantities to be entered into the A, Q, B, or P 
registers or into storage frona the entry keyboard are temporarily held in the 
Communication (C) register until the TRANSFER switch is pushed. If an error 
is made while entering data into the Communication register, the KEYBOARD 
CLEAR switch may be used to clear this register. 

The C register holds words read from storage during a Sweep or Read Storage 
operation. The contents of C are displayed on the console whenever the key- 
board is active. 



*E,T signifies E^t ; E^ signifies E,- 

U ^ Upper L ^ Lowei 
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F Registe r (Main Control): The program control register F holds an instruction 
during the tirne it is being executed. During execution, the program may modify 
the instruction in one of three ways: 

• Indexing (Address Modification) - A quantity in one of the index 
registers (B^) is added to the lower 15 bits of F for word- ad- 
dressed instructions, or to the lower 17 bits of F for character- 
addressed instructions. The signs of Bb and F are extended for 
the addition process. 

• Indirect Addressing - The lower 18 bits of F are replaced by 
new 'a,' 'b', and'm' designators from the original address M 
(modified if necessary, M = m + B ). 

• Indirect Addressing (load and store index instructions) - Bits 
00 - 14 and 1 7 of F are replaced by new 'a' and 'm' designators 
from the original address M (no modification possible). 

After executing an instruction a Normal Exit, Skip Exit, or Jump Exit is perform- 
ed, F is displayed on the console whenever the keyboard is inactive and the 
computer is not in the GO mode. 

Instruction State Register (Main Control): Instruction State register is a 3-bit 
register that is referenced under certain conditions when the computer is oper- 
ating in Executive mode. The (ISR)* are appended to the (P) in the process of 
referencing different program address groups. Refer to Appendix E for the 
different conditions when this register may be used. 

Operan d State Register (Main Control) : Operand State register is also a 3-bit 
register that is referenced under certain conditions when the computer is oper- 
ating in Executive mode. Appendix E describes the conditions when the OSR is 
referenced with regard to the operational state of the CPU. 

Channel Inde x Register (Main Control): The Channel Index register (CIR) is a 
3 -bit register whose contents are logically OR'ed (inclusive OR function) with 
the channel designator 'ch' for the following instructions; 

I/O instructions 
Connect 
Select Function 
Sense External Status 
Copy External Status 
Sense Internal Status 
Copy Internal Status 
Sense Interrupt 

This permits instructions to be written for channel and allows the monitor pro- 
gram to assign the proper channel by altering the (CIR), The (CIR) can be trans- 
ferred by instruction to the lower 3 bits of the A register and vice versa. A 
momentary switch is provided on the console for displaying (CIR) m the lowest 
digit position of the Index register display area. 

*The parentheses, as they are used in this case, are an accepted method for 
expressing the words "the content(s) of" (in this case "the contents of the ISR 
register). 
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Condition Register (Main Control) : Bits in the Condition register (CR) are used 
as flags to initiate computer action and to record current operating conditions 
during Executive mode. With the exception of bit 04, the register is not used 
during non- Executive mode operations. 

All register bits can be set or cleared with the ACR (77. 634) instruction; selected 
bits are set or cleared by individual instructions and conditions, Refer to Section 

4 for special considerations involving the register during interrupt processing. 
The register bit assignments are listed below: 

Bit 00 - Boundary Jump 

Bit 01 - Destructive Load A 

Bit 02 - Operands Relocated Using OSR 

Bit 03 - Program State Jump 

Bit 04 - Interrupt System Enabled 

Bit 05 - Program State 

Data Bus Register (DBR - Main Control) : A 24-bit Data Bus register is used to 
temporarily hold the data received from storage. Communication register, and 
other logic areas. It is a nondisplayed and nonaddres sable register. 

During character-addressed or I/O operations, data entering the DBR may be 
shifted one, two, or three character positions during the transfer to reach the 
correct character position within the DBR. 

Interrupt Mask Register (Main Control) : The 12 -bit Interrupt Mask register 
allows a user to honor or ignore a group of various interrupts by setting the 
register bits to "I's" or "O's". Each register bit corresponds to a particular 
interrupt condition. The mask bits may be set or cleared by executing the SSIM 
and SCIM instructions, respectively. The specific mask register bit assign- 
ments are described in Section 4. 

5 Register (Storage): The S register holds the address of the storage word 
currently being referenced, 

Z Register (Storage) : The Z register is the storage restoration and Modification 
register. Data stored or being transferred to or from the address specified by 
the S register must pass through Z. The entire storage word including the four 
parity bits is represented by the Z register and is displayed on the Storage 
Module control panel. 

Bus Systems 

The Data Bus provides a common path over which data must flow to the storage, 
arithmetic, console typewriter, and I/O sections of the conaputer. These sec- 
tions are connected in parallel to the Data Bus. During the execution of each 
instruction. Main Control determines which data transfer path is activated. 
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An odd parity bit is generated for the lower byte of each word as it leaves the 
DBR during I/O operations. In the case of a 3307 I/O Channel, parity for the 
upper byte of data is generated in the channel itself rather than in the Data Bus. 

The S or Address Bus is a data link between Main Control and storage for trans- 
mitting storage addresses. Inputs to the S Bus are from the P register, F reg- 
ister. Block Control, and the Breakpoint circuits. 

Executive Mode 

The CPU can operate in either the non-Executive mode or Executive mode. In 
non- Executive mode the 3 300 operates identically to the 3200. 

Depressing the EXECUTIVE MODE switch on the operator's console causes the 
3300 to function in the Monitor State of Executive mode. All 3300 instructions 
may be executed in the Monitor State provided the necessary hardware is pre- 
sent in the system. 

After executing a Set Boundary Jump (SBJP) instruction, the next jump instruction 
causes the 3300 to advance to the Program State of Executive mode. In Program 
State, the CPU performs at its highest efficiency by restricting itself to actual 
computations by not executing I/O or Block Control instructions. If a Halt (00. 0) 
instruction, any of the 71-77 instructions (except SBCD 77. 72 and SFPF 77. 71), 
or an inter -register transfer affecting registers 00 through 37 of the register file 
is attempted while in Program State, the 3300 reverts to the Monitor State of 
Executive mode. Additional information can be found in Appendix E. 

Block Control 



Block Control is an auxiliary control section within a 3300 processor. 

In conjunction with the register file and program control, it directs the following 

operations: 

External equipment I/O 

Search/Move 

Real-Time clock 

Console typewriter I/O 

High-speed temporary storage 

Register File: The register file is a 64-word (24 bits per word) rapid access 
memory with a cycle time of 0. 5 usee. Although the programnaer has access to 
all registers in the file with the interregister transfer (53) instruction, certain 
registers are reserved for specific purposes (see Table 1-1)„ All reserved 
registers may be used for temporary storage if their use will not disrupt other 
operations that are in progress. 

The contents of any register in the file may be viewed by selecting the register 
number with the Breakpoint switch and pressing the READ STO switch on the 
keyboard. The contents may be altered by setting the Breakpoint switch, pres- 
sing the WRITE STO switch, and entering a new word from the keyboard. 
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TABLE 1-1, REGISTER FILE ASSIGNMENTS 



Register 
Numbers 



00-07 
10-17 

20 

21 

22 

23 

24-27 

30 

31 

32 

33 

34-77 



Register Functions 



Modified I/O instruction word containing the current character 
address (channel 0-7 control) 

Modified I/O instruction word containing the last address ± 1, 
depending on the instruction (channel 0-7 control) 

Search instruction word containing the current character ad- 
dress (search control) 

Move instruction word containing the source character address 
(move control) 

Real-time clock, current time 

Current character address (typewriter control)* 

Temporary storage 

Instruction word containing the last character address + 1 
(search control) 

Instruction word containing the destination character address 
(move control) 

Real-time clock, interrupt mask 

Last character address +1 (typewriter control)** 

Temporary storage 



*The contents of register 23 should have the following format: 

23 2120 llje oo-« Bit positions 



(0-7) 


W^f 


r 



Must contain the pro- 
gram state number 



\ 



Slashed area should 
contain "O's" 



•Current character address 



**The contents of register 33 should have the following format: 

23 1716 00_ 



Wa 



Slashed area should contain "O's" 



\ 

Last character address plus one 



Block Control Priority: Access to Block Control circuits is shared between the 
computer's main program control and block control buffered functions. Functions 
within Block Control are divided into three groups (Refer to Table 1-2.) The 
five scanners that provide the priority access network for the system are the Pro- 
gram/Buffer scanner, the Group scanner, and the three inner group scanners. 
Figure 1-3 illustrates the scanning pattern of the priority network. 
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The Program /Buffer scanner alternately checks for Block Control requests from 
Program Control and any Group requests. Group requests have priority over 
Program requests and as long as Group requests are present, they will be serv- 
iced before a Program request. When all Group requests have been serviced, a 
Program request can be recognized. 

Another free running scanner checks the three groups for an active Block 
Control request. After a request from one group has been processed, the 
scanner moves to the next group, rotating through the groups in a 3, 2, 1, 3 
order. 

Each group has a four-position scanner. These scanners search from top to 
bottom of their respective groups looking for active Block Control requests. 
After they find a request and it has been processed, the scanners return to the 
top of their group before resuming their search. 



TABLE 1-2, BUFFER GROUPS 



Group 1 


Group 2 


Group 3 


Channel Control 
1 
2 
3 


Channel 4 Control 
5 
6 

7 


Real-time clock control 
Console typewriter control 
Register File Display 
Search/Move Control 



CHANNEL CONTROL 
I 

2 
3 

4 
5 
6 

7 

REAL-TIME CLOCK CONTROL 
CONSOLE TYPEWRITER CONTROL 
REGISTER FILE DISPLAY 
SEARCH / MOVE CONTROL 



PROGRAM 




Figure 1-3. Block Control Scanning Pattern 
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Real-Time Clock 

The real-time clock is a 24-bit counter that is incremented each millisecond to 
a maximum period of 16, 777, 216* milliseconds. After reaching its maximum 
count the clock returns to zero and the cycle is repeated continuously. The 
clock, which is controlled by a 1 kilocycle signal, starts as soon as power is 
applied to the computer. The current time is stored in register 22 of the Reg- 
ister File. It is removed from storage, updated, and compared with the con- 
tents of register 32 once each millisecond. When the clock time equals the 
time specified by the clock mask, an interrupt is set. When necessary, the 
real-time clock may be reset to any 24-bit quantity including zero by loading A 
and then transferring (A) into register 22. Performing a Master Clear does not 
affect the clock count. 

For a special case involving the real-time clock, refer to the Priority Pause 
(PRP) instruction in Section 5. 

Parity 

Parity bits are generated and checked in 3300 systems for the following two 
conditions: 

1. Whenever a data word is read from or written into storage. 

2. When a data word is transferred via an I/O channel. 

Storage Parity : A parity bit is generated and checked for each 6-bit character 
of a storage word. Refer to Figure 1-4. 



27 26 2524 23 



00 



Pq P| P, P3 I 2 3 




\ / J 

CHARACTER DESIGNATORS ' 

PARITY BIT FOR CHARACTER 3 
PARITY BIT FOR CHARACTER 2 
PARITY BIT FOR CHARACTER I 
PARITY BIT FOR CHARACTER 



Figure 1-4. Parity Bit Assignments 

During each Write cycle, a parity bit is stored along with each character. 
When part or all of a word is read from storage, parity is checked for a loss or 
gain of bits. Failure to produce the correct parity during read operations 
causes the PARITY FAULT indicators on the storage module control panel and 
internal status lights to glow. As soon as a parity error is recognized and the 
PARITY STOP switch on console is active, program execution is halted. Master 
clearing the computer clears the fault condition. 



If the PARITY INTERRUPT switch is active and an interrupt is recognized, 
computer enters a special interrupt routine (see Section 4). 



the 



*16, 777,216 milliseconds equals approximately 4 hours and 40 minutes. 
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The total number of "I's" in a character, plus the parity bit, is always an odd 
number in the odd parity system, used in the 3300. 

I/O Parity : The I/O communication channels provide parity lines in addition 
to the other signals that interface with external equipment. Parity is checked 
in the I/O channels to detect parity errors during data transmission to the ex- 
ternal equipment and errors when data is received from external equipment. 
I/O parity errors can be detected by a sensing instruction; however, the parity 
error indicator is not activated. A complete description of I/O parity genera- 
tion and checking may be found in Section 3 of this manual. 

Business Data Processor (BDP) 

The BDP is an optional processor capable of directly executing the business 
oriented instructions listed below and on the next page by their mnemonic codes 
and explained in detail within Section 5. 

64,0 MVE and MVE, DC 

64, 1 MVBF 

64.2 MVZF 

64.3 MVZS and MVZS, DC 
67.2 ZADM 

64.4 FRMT 
64.4 EDIT 

65.0 SCAN, LR, EQ and SCAN, LR, EQ, DC 
65.2 SCAN, LR, NE and SCAN, LR, NE, DC 

65.1 SCAN, RL, EQ and SCAN, RL, EQ, DC 

65, 3 SCAN, RL, NE and SCAN, RL, NE, DC 

66.0 CVDB 

66.1 CVBD 

66.2 DTA and DTA, DC 

66, 3 ATD and ATD, DC 

66.4 PAK 

66. 5 UPAK 

67.0 ADM 

67.1 SBM 

67.3 CMP and CMP, DC 

67.4 TST and TSTN 
70, 6 LBR 

70. 7 SBR 

Upon command from the CPU, the BDP executes the BDP instructions as they 
occur in the program. These instructions all require three instruction words 
(referred to as sub- instruction words) and are stored consecutively, i. e, , at the 
current address defined by P, P+1, and P+2, After executing one of the BDP 
instructions, the processor relinquishes program control to the CPU for con- 
tinued program execution. 

H an interrupt occurs during a BDP Instruction, the BDP relinquishes control to 
the CPU after the current character operation is completed. When the CPU fin- 
ishes interrupt processing, the instruction that was interrupted is again read 
from memory. A restart is usually made at the point of interrupt (CVDB and 
CVBD instructions restart at the beginning - also refer to Illegal Write interrupt 
in Section 4). 
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(B ) is used to indicate at what point in the BDP operation |:he interrupt occurred, 
plus arithmetic carry and second pass information: 

• bit 12 of B^ = "1" if a second pass (complementing operation) was in 

progress. 

• bit 13 of B3 = "1" if an arithmetic carry was generated on an ADM or 

SBM instruction during the iteration prior to interrupt. 
This bit is used for internal machine status to enable 
recovery from an interrupt and must not be construed 
to indicate an arithmetic overflow at instruction 
completion. 
= "1" if floating insertion is set on EDIT. 

• bit 14 of B^ = "1" if a BCD fault occurred. 

• bits 00-11 represent the number of characters or words operated on 
in field C prior to entering the interrupt routine. 

The BDP Condition register (BCR) is a 2-bit register located in the BDP. This 
register is set for conditions existing directly after a business data processing 
operation has occurred. (Refer to Table 1-3. ) The (BCR) are sampled by the 
CPU and a jump may then occur. Refer to the JMP, ZRO; JMP, HI; and JMP, 
LOW instructions. 



TABLE 1-3. BCR GONDITIQINTS 



(BCR)* 


Significance 
for Compare 
(CMP) Instr. 


Significance 
for Arithmetic 
(ADM & SBM) 
Instructions 


Significance 

for Other Instructions 


OO2 

OI2 
1°2 


Field A = Field C 
Field A > Field C 
Field A < Field C 


result positive 
result negative 


operand positive 
operand negative 



*ll2 code is unassigned. 

For BDP instructions containing two fields of variable length, the two fields may 
be assigned as required in memory. However, care should be taken so that over- 
lapping of processed data from the result field and unprocessed data from the 
source field does not occur. The results may be unpredictable if overlapping 
occurs. 

Additional information can be found with the individual BDP instructions in 
Section 5 and Appendix F. 



Rev H 



1-14 



PERIPHERAL EQUIPMENT 

A wide variety of peripheral equipment is available for use with the 3300 com- 
puter. All peripheral equipment available for 3100, 3200, 3300, 3400, 3600, 
and 3800 systems may be attached to a 3306 communication channel. For pro- 
gramming instructions, as well as a list of function codes and status response 
codes, refer to the Control Data 3000 Series Computer Systems Peripheral 
Equipment Reference Manual (Pub. No. 60108800). 
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2. STORAGE SYSTEM 



GENERAL INFORMATION 



The 3300 Magnetic Core Storage (MCS) system receives and transmits storage 
words to the CPU (and BDP if it is in the system). Each storage module pro- 
vides parity checking and visual address and data displays. Each storage (or 
memory) reference requires 1.25 usee within the storage module referenced. 



STORAGE MODULES 

A minimum storage configuration consists of one 3 309 8, 192 word Storage 
Module. An additional 3309 Storage module brings the total storage capacity 
to 16, 384 words. Further storage expansion is provided by adding model 3302 
16, 384 word Storage modules. If the 3300 is equipped with a 3311 Multipro- 
gramming module, 3302 Storage Modules may be added to bring the total MCS 
capacity to 262, 144 words. If the 3311 is not in the system, the maximum MCS 
is 131, 072 words. The 3309 and 3302 Storage modules are shown in Figure 2-1 
along with an enlarged view of their control panels. 



STORAGE REGISTERS 

S Register - The S register receives and holds the storage address, enabling 
address translation for the word currently being referenced. The register 
consists of 13 bits and 14 bits, respectively, in the 3309 and 3302 storage 
modules. 

Z Register - The 28-bit Z register is the storage restoration and modification 
register. All data that is transferred to or from the storage module passes 
through Z. 
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3309 8K Storage Module 



Dual 3309 1 6K Storage Module 



09,00 000 
o- 000 "vjp ono 000 




000000 ooccoc 
oj6.o- 60c o-c^ccac 

■©■ .'■■■!.. 

o<jcr' ece 
o 000 000. ofV! 000 



Dual 3309 Storage Module Control Panel 
Figure 2-1. 3300 Storage Modules 
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3302 Storage Module 
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3302 storage Module Control Panel 



Figure 2-1. 3300 Storage Modules (Cont'd) 
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STORAGE WORD 



A storage word is 28 bits in length of which four bits are used for parity 
checking the remaining 24 bits. The 24 bits, labeled 00 through 23 from right 
to left, may be a single 24-bit instruction, part of a two or three word instruc- 
tion, a zero to 24-bit operand, or part of a larger operand. The storage cor- 
responds to the standard computer word and its format as described in Section 
1. 



CHARACTER MODES 



During a read storage operation, all bits of a word referenced by (S) are read 
out of core storage into the Z register (in parallel) and are restored without modi- 
fication at the same address. For a write storage operation, five basic modes 
exist for modifying (Z) prior to restoration. Any characters not modified are 
restored unchanged. Write Character Designators from the computer or other 
access devices specify the type of write operation to be performed. 



Single-Character Mode 

New data is entered into any one of the four characters prior to restoring the 
word in core. 

Double-Character Mode 

New data is entered into any two adjacent characters (character and 1, 1 and 2, 
or 2 and 3) prior to restoring the word in core. 

Triple-Character Mode 

New data is entered into either of the two possible three- character groups (charac- 
ters 0, 1, and 2, or characters 1, 2, and 3) prior to restoring the word in core. 

Full-Word Mode 

New data is entered into characters 0-3 prior to restoring the word in core. 
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Address Mode 



New data is entered into the lower 15 bits (word address) or the lower 17 bits 
(character address) prior to restoring the word in core. 



ADDRESSING 

The S bus, as described under Bus Systems in Section 1, carries the address of 
the memory location being referenced to the proper storage module. During 
Executive mode, the (ISR)* or (OSR)* are appended to a 15-bit basic address (as 
displayed in the P register) to form an 18-bit address. The upper 3 bits of add- 
ress are forced to zero during non- Executive mode to limit storage addressing 
to 32, 768 words. 

If a storage reference is made for an address contained in a non-existent 
memory module , a high priority interrupt may be entered. Refer to the Storage 
Parity Error-No Response Interrupt in Section 4 for details. 



MULTIPROGRAMMING AND RELOCATION 

The 3311 Multiprogramming Module permits the instructions of many programs 
to be sequentially executed and relocated in MCS under the control of a monitor 
program. The available MCS in a 3300 system is grouped into "memory pages" 
consisting of 2, 048 absolute memory locations. By using a Page Index File and 
advanced logic circuits, the 3311 makes optimum use of memory pages as they 
become available during program execution. 

Appendix E includes detailed information on multiprogramming and relocation 
concepts as applied to the 3300. 



STORAGE PROTECTION 

It is often desirable to protect the contents of certain storage addresses against 
alteration during the execution of a program. There are four categories of ad- 
dresses: those that are always protected, those that are protected at the option 
of the programmer, those that are protected by the multiprogramming and re- 
location features, and those that are never protected during special sequences. 

If any attempt is made to write at a protected address during non- Executive mode, 
the illegally addressed location remains unaltered (Write is changed to a Read), 
the console Illegal Write indicator lights, and program execution continues. The 
illegal write condition is recorded by setting bit 05 of the internal status sensing 
network. The condition is cleared by a Master Clear, an Internal Clear, or by 
sensing. 

* Only the numbers 0, 1, 2 and 3 in the ISR or OSR can be used in the Multipro- 
gramming option is not in the system. 
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During Executive mode, a protected address remains unaltered (Write is changed 
to a Read) during all write operations, except those occuring in Monitor State 
and during Block Control operations. The condition is not recorded on the status 
line. Refer to the Illegal Write interrupt discussion in Section 4 for additional 
information. 

Permanent Protection 

The upper 32 memory locations of the existing MCS are reserved for Auto Load 
and Auto Dump programs when operating in the non- Executive mode. These 
addresses are always protected against alteration by a special storage protec- 
tion circuit. The actual protected addresses depend upon the number of MCS 
locations in a system but always utilize the upper 32 locations in any system. 

Logic circuits sense the total storage capacity of the system and check each 
storage address as it appears on the S (address) Bus to see if it is among the 
protected addresses. If it is one of those to be protected, reading, but no writ- 
ing, is allowed at that address. The only time that this protection is disabled 
is when an operator presses the ENTER AUTO PROGRAM switch on the console 
to enter a new Auto Load or Auto Dump program. 

When operating in Executive mode, the Auto Load and Auto Dump storage areas 
encompass addresses OOSTOOq through 003777o and are protected when referenced 
through Page Index Zero. Refer to Section 3 for additional information on the 
Auto. Load and Auto Dump features. 

Selective Protection 

3304-A Central Processor 

Two different selective protect schemes are available with the 3304-A; one being 
standard and the other available by option. In the standard protect scheme, 15 
three- position toggle switches, corresponding to the basic 15 -bit storage address, 
are set to selectively protect individual addresses or a block of addresses. The 
switches are located on the power control panel as shown in Section 7. 

Table 2-1 describes the three switch positions and Table 2-2 lists examples of 
switch settings. The switches are automatically disabled during execution of the 
BDP instructions (64-70). In Executive mode, the switches apply to an address 
range of which the upper 3 address bits (ISR) or (OSR) are equal to zero. 

TABLE 2-1. STORAGE PROTECTION SWITCH DESCRIPTIONS 



Output 


Switch 
Position 


Description 


Il-l TI 

"N" 
"0" 


Up 
Center 

Down 


Each address protected will have a "l" in this bit position. 

Each address protected may have either a "l" or a "O" in 
this position. For example, when all switches are set to 
the neutral position, all storage is protected, provided ■ 
that the protect feature is enabled. 

Each address protected will have a "O" in this bit position. 
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TABLE 2-2. STORAGE PROTECTION SWITCH SETTINGS 





Examples: 1 


Description of Protected Addresses 


Settings -Storage 
Protection Switches 


Addresses 
Protected (octal) 


Single storage address 


000 000 000 001 111 


00017 


Two nonsequential addresses 
of a group of lOg.* 


000 000 000 010 ONO 
000 000 000 010 NIO 


00020 & 00022 
00022 & 00026 


Four nonsequential addresses 
of a group of lOs.* 


000 000 000 010 NON 
000 000 000 010 NNl 


00020, 00021, 

00024, & 00025 

00021, 00023, 

00025, & 00027 


Four address block - may be the 
upper or lower half of a group of 

lOg.* 


000 000 000 100 ONN 
000 000 000 100 INN 


00040-00043 
00044-00047 


lOg address block 


000 000 000 010 NNN 


00020-00027 


208 address block 


000 000 001 OON NNN 
000 000 001 UN NNN 


00100-00117 
00160-00177 


408 address block - may be the 
upper or lower half of a group 
of lOOs.* 


100 000 000 ONN NNN 
100 000 000 INN NNN 


40000-40037 
40040-40077 


Numerous other groups and com- 
binations of the above groups 
may also be protected. 


000 000 000 NNN 110 

NNN NNN NNN NNN 111 
NNN NNN 001 NNN NNN 


00006, 00016, 
00026 . , , 00076 
All XXXX7 ad- 
dresses 
All XXIXX ad- 
dresses (00100- 
00177, 01100- 
01177, etc.) 



*The first address of all groups of lOg, 208, 408, lOOs etc., must have a low- 
er octal digit of zero. Blocks of 1008, 2008, 4008, lOOOs, 20008, 40008, etc., 
may be protected in the same manner as blocks of 108, 208, & 408. 

The optional protect scheme allows two independent blocks of locations within a 
designated 32K of storage to be protected during non- Executive or Executive 
mode. With this feature, protection can be given to the resident monitor program 
and to another program that may be operating. 

The area increasing in address from address 00000 may be protected in multiples 
of 512-j^Q locations. The area decreasing from address 77777 can similarly be 
protected. The number of locations protected in an area is determined by setting 
the six toggle switches associated with that area; each of the 77o possible settings 
represents one multiple of 512 locations. The six switches labeled 9 through 14 
select the lower protected area; those labeled through 5 select the upper 
protected area (refer to Figure 7-11) , Figure 2-2 illustrates the protection 
scheme. Table 2-3 gives examples of switch settings and their corresponding 
protected areas. 
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Switch settings for both schemes are disabled by pressing the DISABLE STO 
PROTECT switch on the console. 



ADDRESS 77777 



B XX (77 7) 



CXX (0001 



ADDRESS 00 000 



PROTECTED 



UNPROTECTED 



PROTECTED 



Bxx = 6 switches to select upper area address boundary, lower 9 bits of which 
are always " I's" 

Cxx = 6 switches to select lower area address boundary, lower 9 bits of which 
are always "O's" 

Figure 2-2. Optional Protect Scheme 
TABLE 2-3. OPTIONAL STORAGE PROTECTION EXAMPLES 



Bxx 


Locations Protected 


Cxx 


Setting 


(Upper and Lower areas) 


Setting 


76 


OlOOOg = 512 


01 


75 


02000g = 1, 024 


02 


74 


OSOOOg = 1,, 536 


03 


67 


lOOOOg = 4, 096 


10 


57 


20000g = 8, 192 


20 


40 


37000g = 15, 872 


37 


37 


40000g = 16, 384 


40 


36 


41000„ = 16, 896 
o 


41 
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3304-B Central Processor 

The basic 3304-B Central Processor contains no standard storage protection. 
Storage protection is available by option and operates the same as the optional 
protection which is available on the 3304-A processor. 



Program Protection 

When the 3 300 is operating in the Program State of Executive mode, the reloca- 
tion features of the 3311 Multiprogramming module are used by the monitor 
program to protect certain addresses from being altered. 

If the exclusion bit of a particular Page Index is a "1" and PL, t PA, t or PPf 
is a quantity other than zero, PA defines amemory area where only reading is per- 
mitted. If the exclusion bit is "1" and PL, PA.and PP are all equal to zero 
neither reading nor writing is permitted. 

The monitor program controls the relocation process and uses the paging 
system to provide efficient use of memory while processing various programs. 
Appendix E explains in detail the 3300 paging and relocation processes. 

No Protection 

Addresses 00002 through 00005, 00010, 00011, 00014, 00015, 00020, and 
00021, which are used by the interrupt system, are never protected 'during the 
interrupt sequence. 



STORAGE SHARING 

Two 3300 computers may share the memory of a storage module. A switch on 
each storage module control panel allows the operator to give exclusive control 
to the right or left computer. A middle position on this switch actuates a two- 
position priority scanner. Storage control honors the requests in the order 
they are received. Neither computer has priority over the other and the com- 
puter involved in the current storage cycle relinquishes control to the request- 
ing computer at the end of its cycle. Either computer can therefore be delayed 
a maximum of one storage cycle. A similar program delay may occur within 
either computer when an internal scanner determines whether Main Control or 
Block Control has access to the storage module. 

Direct access to 3300 type storage modules is available for certain installations. 
The normal I/O channel route is bypassed and the customer's special equipment 
interfaces directly with the storage logic. 



TRefer to Appendix E for designator descriptions. 
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3. INPUT/OUTPUT SYSTEM 



GENERAL INFORMATION 

Data is transferred between the 3300 Central Processor and Its associated periph- 
eral equipment via a 3306 or a 3307 Communication Channel. The 3306 utilizes 
a 12-bit parallel-transfer byte and the 3307 provides a 24-bit byte. A maximum 
of eight 3306's or four 3307 's and four 3306's may be linked to a single system. 
Both the 3306 and the 3307 are bidirectional and each channel may communicate 
with a maximum of eight peripheral controllers. A data channel can communicate 
with only one device at a given time, however. Each peripheral controller in 
turn may be attached to a number of peripheral devices. Figure 3-1 is a simpli- 
fied block diagram of a 3300 Communication System. 

For programming purposes, the eight possible I/O channels are designated by 
numbers through 7. A 3307 channel will always be an even channel. The total 
number of channels must always be even. Depending upon the user's needs, any 
combination of 330 6's and 3307's may be present provided all the forenamed rules 
are followed. 

A basic 3300 system includes two 3306 Communication Channels or one 3307 
channel and one 3306 channel. Figure 1-1 indicates the location of these channels 
in a fully expanded system. 

Channels and 1 derive their operating power from the CPU. Power for all other 
channels is controlled through the I/O Channel Power Panel shown in Figure 3-2 
and as F in Figure 1-1. The two voltage controls should be adjusted to produce 
0% reading on the meters when the 400 cycle power circuit breaker is turned ON. 
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A maximum configuration of data channels. A smaller configuration may be 
obtained by removing the channels in pairs of odd and even. Any 3307 may be 
replaced by a 3306, but not vice versa. 

Each channel may connect to a maximum of eight equipments. The number of 
devices connected to an equipment depends upon the equipment. 



Figure 3-1. 3300 I/O System 
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Figure 3-2. I/O Channel Power Panel 
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INTERFACE SIGNALS 



Figure 3-3 shows the interface signals between a data channel and its external 
equipment. The twelve status lines are active only between the channel and the 
controller to which it has been connected by a CON (77. 0) instruction. Since a 
Connect instruction causes all controllers on the specified channel to disconnect 
except the one to which it is directed, only one controller may be connected to a 
channel at one time. Thus to check status the program must first Connect the 
device. 

There are eight interrupt lines, one to each controller. A controller need not be 
connected to return an interrupt signal to the data channel. These lines are 
designated as 0-7 and match the Equipment Number switch setting on each con- 
troller. For a complete description of the I/O interface signals as well as an I/O 
timing chart, refer to the 3000 Series Input/Output Specifications Manual, Pub. 
No. 60048800. 
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Figure 3-3. Principal Signals Between I/O Channel and External Equipment 
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3306 AND 3307 COMMUNICATION CHANNELS 

Communication channels provide a buffer between the computation section and 
various peripheral controllers, thus preventing a tie-up of the computation section 
while awaiting a response from an external equipment. Since an I/O section con- 
tains no manual controls or indicators, all operations must be initiated by program 
via the computation section of the computer. Prior to actual data exchange the 
program must execute several instructions which connect the equipment to the 
channel, specify operating conditions, check status conditions, and initiate the 
Read orWrite operation. After the Central Processor initiat es the Input or Output 
operation, a communication channel can exchange data between the peripheral 
device and core storage independent of the Central Processor. 

All assembly and disassembly for the 3306 12-bit channel is done by block control, 
not the 3306. Two memory references are necessary to store or transmit a 24- 
bit word when doing a word addressed I/O instruction with 12- to 24-bit assembly. 
In contrast, the 3307 contains its own assembly/disassembly feature. The assem- 
bly feature allows the channel to receive two 12-bit bytes from an external equip- 
ment and assemble them into a 24-bit word before storing in memory. The dis- 
assembly feature permits the channel to accept a 24-bit word from storage and 
transmit it to an external equipment in 12 -bit bytes. 

The 3307 also facilitates a convenient interface with a 24-bit I/O device. The 
24-bit transfers between memory and the 3307 reduce to one the number of mem- 
ory references necessary to execute a word addressed I/O instruction. Thus the 
3307 is adapted for use with high-speed 12- and 24-bit I/O devices. When doing 
character addressed instructions, it acts as a 3306. 

I/O PARITY 

Parity Checking With the 3306 

The computer checks parity by one method for Connect, Function, and Write 
operations and by a second method for Read operations. External equipment 
responds differently to parity errors for a Connect than for a Function, Read, 
or Write. For details on external equipment responses to parity errors see 
3000 Series Peripheral Equipment Reference Manual, Pub. No. 60108800. 

Connect. Function, and Write 

During the Connect, Function, and Write operations the Data Bus circuit of the 
computation section generates a parity bit and sends it to the external equipment 
with each 12-bit byte via the I/O channel. The external equipment generates a 
parity bit and compares it with the parity bit from the computer. 

Connect : If a parity error exists in a Connect instruction, the external equipments 

• do not connect 

• disconnect if already connected 
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• do not return an External Parity Error signal 

• generally light a Parity Error indicator on the external equipment, and 

• return neither a Reply nor a Reject signal. 

After 100 usee the computer issues an Internal Reject. 

Function and Write: If a parity error exists in a Function or Write instruction, 
the connected external equipment sends an External Parity Error signal back to 
the I/O channel. This signal causes the logic within the channel to provide a "1" 
on sense line zero. This logic is cleared every time an attempt is made to exe- 
cute a Connect^ Function, Read, or Write operation on this channel; however, 
these operations do not necessarily clear the logic in the external controller that 
transmits the External Parity Error signal. Thus to guarantee clearing this 
sense line the external equipment must also be cleared. Both the I/O channel 
and the external equipment may be channel cleared by the program or master 
cleared by the operator. If a transmission parity error is received from a con- 
troller, the controller remains inactive until both the external equipment and the 
I/O channel are cleared. A new I/O sequence naust be initiated to continue or 
repeat the I/O operation. 

Read 

During a Read operation, the external equipment generates a parity bit and sends 
it to the I/O channel along with each 12-bit byte of data. The I/O channel holds 
the parity bit while the data is forwarded to the computation section. The Data 
Bus circuit of the computation section generates a second parity bit and sends it 
back to the I/O channel. The channel compares this second signal with the Parity 
signal which was generated by the external equipment. H an error exists, certain 
channel logic is set by an enable from the computation section. This logic provides 
a "1" on sense line zero. The channel parity logic is cleared every time an attempt 
is made to execute a Connect, Function, Read, or Write operation with this chan- 
nel. It may also be channel cleared by the program or master cleared by the 
operator. If a transmission parity error is channel generated, it must be sensed 
by the INS instruction. If th.e error is not sensed, the next channel operation 
clears the error indication. 



Parity Checking With the 3307 

The computer checks parity with a 3 307 in a slightly different manner than with a 
3306. 

Connect, Function, and Write 

During the Connect, Function, and Write operations the Data Bus circuit in the 
computation section generates one parity bit for the lower 12Tbit byte of data and 
one parity bit for the upper 12-bit byte. Both parity bits are sent to the external 
equipment via the I/O channel. The external equipment generates parity bits and 
compares them with the parity bits from the computer. The remainder of the 
parity checking is identical to that of the 3306 for Connect and for Function and 
Write. 
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Read 

During a Read operation, the external equipment generates two parity bits per 
data word (one for each 12-bit byte) and sends them to the 3307 with the word. 
The 3307 holds the parity bits as the data is forwarded to the Data Bus circuit 
of the computer. Parity is generated in the Data Bus circuit and is sent back 
to the I/O' channel where a comparison is made with the parity bits received 
from the external equipment. 

If a parity error exists, the channel parity logic is set by an enable from the 
computation section, thus providing a "1" on sense line zero. Clearing the logic 
also occurs the same way as it does in the 3306. If a transmission parity error 
is channel generated, it must be sensed by the INS instruction. E the error is 
not sensed, the next channel operation clears the error indication. 



TRANSMISSION RATES 



The rate of transmitting each 12-bit word of I/O information depends upon the 
number of channels active, interregister transfers, the use of pause instructions 
to block out main control or the real-time clock, the length of connecting cables, 
and the use of multiprogramming. The 3000 Series Input/Output Specifications 
Manual, Pub. No. 60048800, describes in detail the measurement of these transfer 
rates using a variable- speed channel execiser. The exerciser meastires the trans- 
fer rate by indicating a Lost Data condition when its speed exceeds that of the data 
channel. Word addressed I/O instructions with 12- to 24-bit Assembly/Disassem- 
bly were used. 

Assuming a safe maximum transfer rate to the 10 percent slower than the average 
of the rates at which a Lost Data condition occurred, the following cases serve as 
examples of realizable transfer rates. 



Without multiprogramming: 

1. Using a 3307 on channel 4, doing 
I/O only, blocking main control 
and the real-time clock with a 
Priority Pause instruction. 

2. Standard rate, no restrictions on 
program, channel and 1 active, 
channel is a 3307, channel 1 is 
a 3306. 



Maximum Transfer Rate 
(12 -bit word) 



2. usee 



8. usee (channel 0) 
20. usee (channel 1) 
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With multiprogramming 

1. Using a 3306 on channel 0, 4. 2 usee 
doing I/O only, blocking main 

control and the real-time clock 
with a Priority Pause. 

2. Standard rate, no restrictions 16. usee (channel 0) 
on program, channels and 4 16. usee (channel 4) 
active, both are 3306 's. 

The measured transfer rates when doing relocation were 0. 2-. 3 usee greater. 



INPUT/OUTPUT RELOCATION 

Data may be transmitted to or from several block locations in storage by using 
relocation. When an I/O instruction is encountered while executing a program in 
Executive Mode, Program State, an Executive Interrupt returns the computer to 
Monitor State. When a 3311 is present in the system the relocation of I/O infor- 
mation now occurs in the same manner as the relocation of a program. The mon- 
itor recognizes and assigns the appropriate I/O channels and devices. Whether 
or not relocation occurs, the largest block of data which may be transferred by 
a single I/O instruction is 32K 24-bit words. 



AUTO LOAD /AUTO DUMP 

The Auto Load and Auto Dump feature of the computer allows the programmer 
two groups of continuous storage locations for storing frequently used subrou- 
tines. These subroutines m.ay be used whenever it is desirable to call in a 
particular tape unit or some other function that initiates an operation. 

By depressing the AUTO LOAD console switch when the computer is stopped 
and in the non-Executive mode, the computer automatically jumps to address 
77740 and executes the instruction stored there. The Auto Load routine is 
allotted sixteen addresses, 77740 through 77757. 

Depressing the AUTO DUMP switch under the same conditions as Auto Load 
causes the computer to jump to address 77760 and execute the instruction stored 
there. Sixteen addresses, 77760 through 77777^ may be used for the Auto Dump 
routine. 

Although these storage areas may be used for any routine, the Auto Load area 
is generally used to bring in a program from a magnetic tape unit or other 
peripheral device. The last instruction in this routine should be a jump to the 
first address of the program just called in. 

The Auto Dump area is most often used to output a block of data to a magnetic 
tape unit or other peripheral equipment and the last instruction in this routine 
can be a jump to any storage area within the confines of the system. 



3-7 Rev. F 



When the computer is operating in Executive mode, the Auto Load routine is 
stored in thirty- two locations encompassing addresses 003700 through 003737. 
The Auto Dump likewise has thirty-two locations ranging from address 003740 
through 003777. The PA and PP designators of the page index associated with 
Page Index File zero are always zero thus providing a definitive area of storage 
(page zero) where the Auto Load and Auto Dump routines may be stored. The 
Auto Load and Auto Dump addresses are always protected in Non-Executive mode. 

Examples of entering programs into the Auto Load and Auto Dump storage 
areas are given in Section 7. 
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4. INTERRUPT SYSTEM 



GENERAL INFORMATION 

The Interrupt System of a 3300 Computer can sense for the presence of certain 
internal and external conditions without having these tests in the main program. 
Examples of these conditions are internal faults and external equipment end-of- 
operation. Near the end of each RNI cycle, a test is made for interruptible 
conditions. If one of these conditions exists, and the interrupt system is en- 
abled; execution of the main program halts, the contents of the Program Ad- 
dress register are stored, and an interrupt routine is initiated. This interrupt 
routine previously stored in memory, performs the necessary functions for the 
existing condition and then jumps back to the last unexecuted step in the main 
program. The instruction being read when the interrupt is recognized is exe- 
cuted when the main program is resumed. 

There are seven categories of interrupts in the 3300 Computer: Internal Condi- 
tion interrupts, l/O interrupts. Executive interrupt. Parity Error interrupt. 
Illegal Write interrupt. Trapped Instruction interrupts, and Power Failure in- 
terrupt. The store operations required for all types of interrupts occur regard- 
less of the settings of the storage protection switches described in Section 2. 

An additional programming feature is the MANUAL INTERRUPT switch on the 
operator's console. This interrupt is not masked since this switch is activated 
only when it is desirable to interrupt the computer, however, the interrupt 
system must be first enabled. The manual interrupt condition is automatically 
cleared after the interrupt is recognized. 

When the 3300 is operating in the Program State of Executive mode, any inter- 
rupt that is recognized causes the processor to revert to the Monitor State. An 
Executive interrupt (described later in this section) also causes the processor 
to revert to the Monitor State if an attempt is made to execute one of several 
particular instructions. 
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INTERRUPT CONDITIONS 

Internal Condition Interrupts 

Any one of six internal conditions may cause an interrupt during the execution 
of a program. These conditions and their descriptions follow. 

Arithmetic Overflow Fault 

The Arithmetic Overflow fault is set when the capacity of the adder is exceeded. 
Its capacity, including sign, is 24 or 48 bits for 24-bit precision and 48-bit 
precision, respectively. 

Divide Fault 

The Divide fault sets if a quotient, including sign, exceeds 24 or 48 bits for 
24-bit precision and 48-bit precision, respectively. Therefore, attempts to 
divide by too small a number, including positive and negative zero, result in a 
Divide fault. A Divide fault also occurs when a floating point divisor is either 
equal to zero or not in floating point format. The results in the A, Q, and E 
registers are insignificant if a fault occurs. A Divide fault can be correctly 
sensed only after the current instruction has been executed. 

Exponent Overflow /Underflow Fault 

During all floating point arithmetic operations, exponential overflow occurs if 
the exponent exceeds +1777g or is less than -1777g. The fault is also set if 
the SFPF (77. 71) instruction is executed. 

BCD Fault 

The BCD fault is generated by the BDP module if: 

1. The lower 4 bits of any character in field A (except the sign character) 
exceed lln during a numeric character operation. 

2. The lower 4 bits of the sign character in field A exceed 123 during a 
numeric character operation. 

3. The upper 2 bits of any character in field A (except the sign character) 
do not equal 00 during a numeric character operation. 

4. An arithmetic carry out of the highest order character of field C occurs 
during an ADM or SBM instruction. 

5. Field length Si> S2 ^°^ ^^ ADM or SBM instruction. 

6. Field length Si v^ S2 ^°^ ^ PRMT instruction, including provision for 
insertion characters. 

7. A carry occurs out of the 14th character position during a CVBD 
instruction. 

8. A field (Si) of more than 14 BCD characters is specified during a CVDB 
instruction. 

9. Bits 05 and 06 of an ASCII character are both "I's" or both "O's" during 
the execution of an ATD instruction. 

The BCD Fault may also be set by executing the SBCD (77, 72) instruction. 
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Search/ Move Interrupt 

The Search/Move control may be programmed to generate an interrupt during 

a 71 or 72 instruction for either of the following conditions: 

1. Completion or satisfaction of an equality or inequality search instruc- 
tion (SRCE or SRCN). 

2. Completion of a block move (MOVE instruction). 

Real-Time Clock Interrupt 

The Real-Time Clock interrupt is generated when the clock reaches a time 
previously stored in register 32 of the Register File. 

Input/Output Interrupts 

I/O Channel Interrupts 

Any of the eight possible I/O channels may be programmed to generate an inter- 
rupt for either of the following conditions: 

1. Reaching the end of an input or output block. 

2. Receiving an End of Record (Disconnect) signal from an external 
device. 

I/O Equipment Interrupt 

The I/O equipment interrupt is set when an interrupt signal is received from 
any of eight peripheral equipment controllers connected to any of the eight 
possible I/O channels (there may be a total of 64 interrupt lines). 

Associated Processor Interrupt 

In a system of two or more processors (computers), each processor may inter- 
rupt, or be interrupted by, one other processor by executing an lAPR (77. 57)^ 
instruction. This interrupt is not masked and becomes cleared as soon as it is 
recognized. 



Executive Interrupt 

The Executive Interrupt can only occur when the computer is operating in the 
Program State of Executive mode. An attempt to execute one of the following 
instructions then generates an Executive interrupt. 

1. Halt instruction (00. 0) 

2. Inter- register transfer instructions with the Register File locations 00 
through 37, [i3.(4-7) (1-3) (XX00-XX37)] 
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3. Instructions with octal codes 71 through 77 except the 77. 71 SFPF and 
77. 72 SBCD instructions 

This interrupt is not masked and has priority over all of the internal condition 
interrupts. When the Executive interrupt has been recognized and the computer 
has reverted to the Monitor State, any of the instructions in the three categories 
above can be executed. 

Storage Parity Error— No Response Interrupt 

A Storage Parity Error interrupt has the highest priority of all interrupts and 
can occur if either a storage parity error is detected or if a storage module does 
not respond when referenced. The interrupt condition is recognized during the 
RNI and RADR sequence for an instruction. 

The PARITY INTERRUPT switch on the console must be active for the interrupt 
to occur. If the PARITY STOP switch is active, the computer stops when a 
parity error or no-response condition is detected. The two switches cannot be 
simultaneously active, and pressing the PARITY STOP switch overrides the 
Parity Interrupt condition. 

If Block Control has storage priority at the time of interrupt, the address of the 
next instruction to be executed is stored in the lower 15 bits of location 00020. 
The appropriate register file location contains the approximate address where 
the error occurred. An interrupt during Main Control priority causes the address 
of the current instruction to be stored in location 00020. If the error condition 
is detected during any of the RNI's for the BDP instructions, (P) is always stored 
at location 00020. Detecting the condition during either RNI for the 71-76 instruc 
tions results in either (p), (p + 1), or (P + 2) being stored. 

A code representing conditions within the processor at the time of interrupt is 
automatically stored in the lower 12 bits of location 00021. A RNI is then per- 
formed at location 00021. The stored address and code enable the interrupt 
routine to isolate the storage area where the error occurred and aid in program 
recovery. Table 4-0 lists the various codes and their interpretations. 

The instruction in progress when the interrupt is detected may be executed al- 
though the results are not necessarily correct. Once the parity error or no- 
response condition is detected, additional errors are not recognized until a DINT 
(77. 73) instruction is executed. 
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TABLE 4-0. PARITY ERROR INTERRUPT CODES 



Reason for Interrupt 


Type of Operation or 
Sequence in Progress 


Code 


No- Response 


Block Control - (73-76) 


00X0 


X = ch 


Parity Error 


Block Control - (73-76) 


00X2 


X = ch 


No-Response 


Block Control - 71, 72, or 

typewriter I/O 


01X0 


(X=0. 
(X=l, 
(X=3, 


Srch), 
Move) , 
TWR) 


Parity Error 


Block Control - 71, 72, or 

typewriter I/O 


01X2 


(X=0, 
(X=l, 
(X=3, 


Srch), 
Move) , 
TWR) 


No-Response 


Main Control - RNI or RADR 


00X1 


(X=0, 
(X=2, 


RNI) 
RADR) 


Parity Error 


Main Control - RNI or RADR 


00X3 


(X=0, 
(X=2, 


RNI) 
RADR) 


No-Response 


Main Control - ROP or STO 


0005 






Parity Error 


Main Control - ROP or STO 


0007 







Illegal Write Interrupt 

This interrupt has priority over all interrupts except the Storage Parity Error 
interrupt. The interrupt condition may result during a RNI, RADR, ROP, or 
STO sequence; however it is recognized only during RNI or RADR, When the con- 
dition is recognized, the interrupt system is disabled, (P) are automatically 
stored at address 00014, and an RNI is performed at address 00015. 

The system must be in Program State of Executive mode to recognize the inter- 
rupt. The interrupt is disabled during Monitor State and during Search/Move and 
I/O cycles. The conditions for the interrupt are listed below. (Conditions 3 
through 6 apply only if the 3311 Multiprogramming Module is present in the sys- 
tem, ) 

1, A Write operation into an area protected by the Storage Protect 
switches (Program State 0), 

2, A Keyboard Write operation into the Executive Auto Load/Auto Dump 
area (addresses 03700 through 03777), 

3, A Read or Write operation when bits 9 and 10 of the original address 
specify a quarter page equal to or greater than PL, when PL 4 0. 

4. A Read or Write operation if the 'E' designator for any referenced 
index equals "l" and PA, PL, and PP are equal to zero. 

5. A Write operation if the 'E' designator for any referenced index equals 
"1" and PA, PL, or PP is not equal to zero, 

6. A double precision instruction if the first operand is to be read from 
the last available memory location specified by PL, or if from the 
last memory location when PL specifies a full page and the next index 
to be used contains 4000. 
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Bit 05 of the internal status sensing network is set on an niegal Write interrupt 
only if the condition occurred during a RNI or RADR sequence. H the condition 
occurred during a ROP or STO sequence, the interrupt is generated but bit 05 is 
not set. E one of the 66. 0-66.5 instructions is interrupted by an Illegal Write, 
the instruction always restarts at the beginning when the main program resumes. 
Other BDP instructions restart from the point of interrupt. 

Trapped Instruction Interrupts 

If an attempt is made to execute one of the instructions listed in Table 4-1 and 
the system is not equipped with a 3310 Floating Point module or 3312 BDP, the 
instruction becomes trapped. Only those instructions preceded by an asterisk 
(*) are trapped if the 3312 BDP is not present in the system and the 3310 Float- 
ing Point module is present. 



TABLE 4-1. TRAPPED INSTRUCTIONS FOR NON-EXECUTIVE 
MODE WITHOUT A 3310 OR 3312 MODULE IN SYSTEM 

(MNEMONIC LISTING) 



ELQ 


*MVE 




*SCAN,LR,NE, 


DC 


*UPAK 


EUA 


*MVE , DC 




*SCAN,RL, 


EQ 




*ADM 


EAQ 


*MVBF 




*SCAN,RL, 


EQ, 


DC 


*SBM 


QEL 


*MVZF 




*SCAN,RL, 


NE 




*CMP 


AEU 


*MVZS 




*SCAN, RL, 


NE, 


DC 


* CMP, DC 


AQE 


*MVZS,DC 




*CVDB 






*TST 


MUAQ 


*ZADM 




*CVBD 






* J MP, HI 


DVAQ 


*FRMT 




*DTA 






* J MP, LOW 


FAD 


*EDIT 




*DTA,DC 






*JMP , ZRO 


FSB 


*SCAN,LR, 


EQ 


*ATD 






*SBR 


FMU 


*SCAN, LR,EQ,DC 


*ATD,DC 






*LBR 


FDV 


*SCAN,LR, 


NE 


*PAK 









Each instruction listed in Table 4-2 is processed as a no-Operation instruction, 
(refer to Section 5) if an attempt is made to execute one of them while operating 
in the non-Executive mode. 



TABLE 4-2. NO-OPERATION INSTRUCTIONS 
FOR NON-EXECUTIVE MODE 
(MNEMONIC LISTING) 



A CI 


ISA 


ROS 


AIS 


JAA 


SBJP 


AOS 


OSA 


SDL 


APF 


PFA 


SRA 


CIA 


RCR 
RIS 


TMAV 
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Although they are not true interrupts, trapped instructions are processed like 
interrupts once they have been detected. A conventional interrupt always takes 
priority over a trapped sequence. 

The following operations take place when a trapped instruction is recognized: 

1. The address of the next sequential program step, P + 1, is stored in 
the lower 15 bits of address 00010. 

2. The upper 6 bits of the instruction in the F register are stored in the 
lower 6 bits of the operand stored at address 00011. The upper 18 
bits of this operand remain unchanged. 

3. Program execution commences at address 00011. 

EXAMPLE: MUAQ (56) Instruction execution attempt without the 

Floating Point/Double Precision hardware option in the 
system. p- — 



Address P 
Address P + 1 



54430 



56 



30390 



54431 




00010 

00011 14 000(56)«- 



At this point the MUAQ operation may be simulated 
by software and re-entry to the main program is 
possible by a jump to the contents of address 00010. 



Power Failure Interrupt 

If source power to the computer system fails, the power failure is detected and 
the computer program is interrupted. This interrupt is necessary to prepare a 
controlled shutdown and prevent the loss of data. The operation requires 16 ms 
for detection, and up to 4 ms for processing the special Power Failure interrupt 
routine. 

The Power Failure interrupt overrides any other interrupt except the Illegal 
Write and Storage Parity Error interrupts, regardless of the state of interrupt 
control. Since this interrupt overrides all others, the address where the pres- 
ent contents of P are stored and the address to which program control is trans- 
ferred must be different from that for a normal interrupt. When a Power 
Failure interrupt occurs, the machine stores the contents of P in the lower 15 
bits of address 00002 and transfers program control to address 00003. 

The normal interrupt system is disabled during a power failure sequence; i. e. , 
the hardware simulates the execution of a DINT (77. 73) instruction. 
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INTERRUPT CONTROL 



Through the use of certain instructions, a program can recognize, sense, and 
clear interrupts, and enable or disable the interrupt system. 



Enabling or Disabling Interrupt Control 



Instruction EINT (77. 74) enables the interrupt system and the DINT instruction 
(77. 73) disables it. After recognizing an interrupt and entering the interrupt 
sequence, other interrupts are disabled automatically. When leaving the interrupt 
subroutine, the interrupt system must again be enabled by the EINT instruction if 
interrupts that are waiting or subsequent interrupts are to be recognized by the 
system. Refer to the EINT (77.74) instruction in Section 5 for special conditions 
regarding the actual interruption of the CPU. 



Interrupt Priority 

An order of priority exists between the various interrupt conditions. As soon as 
an interrupt becomes active, the computer scans the priority list until it reaches 
an interrupt that is active (not necessarily the interrupt that initiated the scanning) 
The computer processes this interrupt and the scanner returns to the top of the 
list where it waits for another active interrupt to appear. Table 4-3 lists the 
order of priority. 

TABLE 4-3. INTERRUPT PRIORITY 



PRIORITY 


TYPE OF IN'i'ERRUPT 


PRIORITY 


TYPE OF INTERRUPT 


1 


Storage Parity Error 


8 


BCD Fault 


2 


Illegal Write 


9-72 


I/O Equipment (External)* 


3 


Power Failure 


73-80 


I/O Channel** 


4 


Executive 


81 


Search /Move 


5 


Arithmetic Overflow 


82 


Real-time Clock 


6 


Divide Fault 


83 


Manual 


7 


Exponent Overflow/ 


84 


Associated Processor 




Underflow 


85 


Trapped Instruction 



* There are eight interrupt lines on each of the eight possible I/O channels, or 
64 lines in all. On any given channel, a lower numbered line has priority 
over a higher numbered line. Likewise, a lower numbered channel has 
priority over a higher numbered channel. Example: line of channel has 
highest priority of all external I/O interrupts, line of channel 1 has second 
highest, and line 7 of channel 7 has the lowest. 

i** A lower numbered I/O channel interrupt has priority over a higher numbered 
I/O channel interrupt. 
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Sensing Interrupts 

The programmer may selectively sense interrupts by using the INTS (77. 4) 
instruction. Sensing the presence of internal faults automatically clears them. 
Interrupt lines representing channels not present in the system are sensed as 
being active. The interrupt system need not be enabled for sensing. 



Clearing Interrupts 

Internal condition interrupts are cleared by: 

• Sensing with an INTS (77. 4) or INS (77. 3), after which interrupts are 
automatically cleared, 

« Executing an INCL (77. 50) instruction 

• Executing an lOCL (77. 51) instruction - clears only Search/Move inter- 
rupt, or 

• Pressing the MC or INTERNAL CLEAR buttons. 

I/O channel interrupts are cleared by: 

• Executing an INCL (77. 50), lOCL (77. 51), or CLCA (77. 512) instruction, 
or 

• Pressing the MC or EXTERNAL CLEAR buttons. 

I/O equipment interrupts are cleared by: 

• Executing an lOCL (77. 51) instruction, 

• Reselecting or releasing the interrupt with a SEL (77. 1) instruction, or, 

• Pressing the MC or EXTERNAL CLEAR buttons. 

The manual and associated processor interrupts are automatically cleared upon 
recognition by the computer. 



INTERRUPT PROCESSING 



Four conditions must be met before an Internal Condition, Executive, or I/O 
interrupt can be processed: 

1. A bit representing the interrupt condition must be set to "1" in the Inter- 
rupt Mask register (except for Manual, Associated Processor, and 
Executive interrupts) . 

2. The interrupt system must have been enabled (except for Executive Inter- 
rupt) . 

3. An interrupt- causing condition must exist. 
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4. The interrupt scanning logic (Refer to Table 4-3) must reach the 
level of the active interrupt on the priority list. 

When an active interrupt has met the above conditions, the following takes 
place: 

1. The Instruction in progress proceeds until the point is reached in the 
RNI or RADR cycle where an interrupt can be recognized. At this time 
the count in P has not been advanced nor has any operation been initiated. 
When an interrupt is recognized, the address of the current unexecuted 
instruction in P is stored in address 00004. 

2. A number representing the interrupt- causing condition is stored in the 
lower 12 bits of address 00005 without modifying the upper bits. Table 
4-4 lists the octal codes which are stored for each interrupt condition. 

3. Program control is transferred to address 00005 and an RNI cycle is 
executed. 



TABLE 4-4. REPRESENTATIVE INTERRUPT CODES 



Conditions 



External interrupt 

I/O channel interrupt 

Real-Time Clock interrupt 

Arithmetic overflow fault 

Divide fault 

Exponent overflow fault 

BCD fault 

Search/move interrupt 

Manual interrupt 

Associated processor interrupt 

Executive Interrupt 



Codes 



*00LCh 
OlOCh 
0110 
0111 
0112 
0113 
0114 
0115 
0116 
0117 
0120 



*L = line 0-7 and Ch = channel designator, 0-7 



INTERRUPT MASK REGISTER 

The programmer can choose to honor or ignore an interrupt by means of the 
Interrupt Mask register. All but three of the normal interrupt conditions are 
represented by the 12 Interrupt Mask register bits. The Manual, Associated 
Processor and Executive interrupts are not masked. The mask is selectively 
set with the SSIM (77. 52) instruction and selectively cleared by the SCIM (II. t)6) 
instruction. See Table 4-5 for Interrupt Mask register bit assignments. 

The contents of the Interrupt Mask register may be transferred to the upper 12 
bits of the A register for programming purposes with the COPY (77. 2) or CINS 
(77. 3) instructions. 
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TABLE 4-5. INTERRUPT MASK REGISTER BIT ASSIGNMENTS 



Mask Bits 


Mask Codes 


Interrupt Conditions Represented 


00 


0001 


I/O Channel O"^ 




01 


0002 


1 




02 


0004 


2 




03 


0010 


3 


(Includes interrupts 


04 


0020 
0040 


4 
5 


f- generated within the 


05 


channel and external 


06 


0100 


6 


equipment interrupts. ) 


07 


0200 


7j 




08 


0400 


Real-time clock 


09 


1000 


Exponent overflow /underflow and BCD 
faults 


10 


2000 


Arithmetic overflow and divide faults 


11 


4000 


Search/Move completion 



INTERRUPTS DURING EXECUTIVE MODE 

Although all interrupts can be recognized during Executive mode, special 
consideration must be given to handling these interrupts. During Executive 
mode, the Condition register records current operating information that must 
temporarily be stored in the event of interrupt to enable proper recovery. 
Table 4-6 lists the Condition register bit assignments. 

TABLE 4-6. CONDITION REGISTER BIT ASSIGNMENTS 



Bit 


Condition 


Represented 


00 


Boundary Jump 


Set by SBJP (77. 62) instruction. 
Cleared by next jump instruction. 


01 


Destructive Load A - 


Set by SDL (77. 624) instruction. 
Cleared by next LDA instruction. 


02 


Operands Relocated - 


Set by ROS (55. 4) instruction. 




Using OSR 


Cleared by RIS (55. 0) instruction. 


03 


Program State Jump- 


Set by any jump during Program State. 
Cleared when jumping to Program State. 


04 


Interrupt System 


Set by EESTT (77. 74) instruction. 




Enabled 


Cleared by DINT (77. 73) instruction. 


05 


Program State 


Set when jiomping to Program State. 



To insure the processing of stacked interrupts, it is necessary to transfer these 
conditions to the A register at the start of the interrupt routine by executing a 
CRA (77, 63) instruction. At the completion of the interrupt routine, these 
conditions must be restored by executing a ACR (77. 634) instruction. 
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Upon interrupt recognition, the interrupt system is automatically disabled and 
the Central Processor enters the Monitor State. The Condition register and all 
interrupts, except Trapped Instruction interrupts, are disabled during the inter- 
vals between interrupt recognition and CRA instruction execution, and between 
execution of the ACR instruction and the jump instruction normally used to exit 
from an interrupt routine. 

The Condition register is cleared as the transfer to A is completed; the interrupt 
system remains disabled until a EINT (77. 74) or ACR instruction is executed. 
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5. INSTRUCTIONS 



GENERAL INFORMATION 

A 3300 machine coded instruction word is 24 bits in length and may require up 
to three sequential words for a particular function. Although there are 24 dis- 
tinct instruction formats, as illustrated in Appendix D, there are several that 
are used more frequently than others. These formats (word oriented, character 
oriented, and business oriented) are shown in the following pages along with 
their appropriate instruction parameters. 

Instruction Parameters 

The following parameters are used in the 3300 instruction list. A capitalized 
letter generally indicates a modified parameter, however, this is not always 
the case and the specific instruction should be consulted. Some parameters are 
general in nature, i.e., specifying a character address, but in some instances 
naay indicate a high order address and in others a low order address. The 
parameter descriptions listed below each instruction format should be checked 
for the explicit memory of the parameters for that particular instruction. 

If an octal number appears in the format of a specific instruction, only that 
number must be placed in the exact position as indicated. In cases where only 
a single binary position is involved, a "1" or ''0" is used depending upon the 
instruction. The following parameters are used throughout the 3300 instruction 
list: 

A = (1) variable length field of characters designated field A 

in BDP instructions; usually the transmitting field. 

(2) A is used in the descriptions for instructions (other 
than those for BDP) to indicate the A register. 

a = addressing mode (a = "0" for direct addressing, a = "1" 

for indirect addressing) 

B = "1" for backward storage 

b = index register designator 1, 2, or 3, 
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B = index register flag for a field in certain BDP instructions. 

The flag indicates which index register will have its con- 
tents added to the unmodified address 'm'. M = m + [ Bj-^] 
for these instructions only. 

B = index register flag for a field in certain BDP instructions 

where both fields are specified by word addresses. The 
flag indicates which index register will have its contents 
added to the unmodified address 'n'. 

B = index register flag for field A in most BDP instructions 

(refer to individual instruction descriptions). Initial 
character address of field A is defined: R = r + [ Bj^] . If 
Bj, = 1 or 3, use (B^); if Bj, = 2, use (B^); if Bj, = 0, no 
indexing is performed and R = r. 

Bg = index register flag for field C in most BDP instructions 

(refer to individual instruction descriptions). Initial 
character address of field C is defined: S = s + [ Bg] . 
If Bg = 1 or 3 use (B^); if B g = 2, use (B^); if Bg = 0, no 
indexing is performed and S = s. 

C = variable length field of characters designated field C in 

BDP instructions. Usually the receiving field. 

ch = denotes I/O channel (0 through 7). 

DC = indicates delimiting character position within the instruction 

word or mnemonic. Generally, a delimiting character of 6 
or 8 bits is specified in an instruction and if a character is 
recognized, during the particular operation, that equals the 
delimiting character, the operation is terminated. 

G = "i" for word count control with the INPC and INPW instruc- 

tions. 

H = indicates special Assembly/ Disassembly operation in 

certain character oriented I/O instructions. 

INT = "l" for interrupt upon completion in certain I/O instructions. 

I = assembly language designator indicating indirect addressing. 

i = internal parameter (decrement or increment). 

j = Jump designator. 

k = (1) unmodified shift count for SHA,SHQ, and SHAQ 

instructions. 
(2) scale factor for SCAQ instruction. 

K = (1) modified shift count, K = k + (B^) for SHA,SHQ, 

and SHAQ instructions. 
(2) residue quantity for SCAQ instruction. 

S = field length of data block for MOVE instruction. 

S^ ~ number of characters in BDP field A (character count). 

§2 = number of characters in BDP field C (character count). 
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m = unmodified 15-bit storage word address. 

M = modified 15-bit storage address. M = m + (B ). 

n = same as 'm', but the word address of the second operand 

for certain I/O instructions. 

N = indicates special Assembly/Disassembly operation in 

certain word oriented I/O instructions. 

r = unmodified 17-bit character address. 

R = modified 17-bit character address: 

R = r + (Br) for BDP instructions. (Refer also to 'Bj.'. ) 
R = r + (BD) for all other instructions, 

s = same as 'r', but the character address of the second oper- 

and for certain I/O instructions. 

S = (1) modified 17-bit character address of field C for BDP 

instructions only. S = s + (Bg). (Refer also to 'Bg', ) 

(2) also used to denote sign extension for certain instruc- 
tions. 

SC = 6 -bit comparison scan character used in search instructions. 

May be used with DC. 

V = a specific register number (00-77) within the Register 

File. 

w = 7-bit Page Index File address. (Refer to APF and PFA 

instructions and Appendix E for additional information. ) 

X = connect code or interrupt mask. 

y = 15-bit operand 

z = 17-bit operand 

1 1 1 1 1 1 - slashing indicates a particular area of an instruction that 

should be loaded with zeros although the particular area is 
not used for the instruction. 

In addition to the instruction parameters, various abbreviations are used in the 
instruction descriptions that refer to various registers and operations. These 
abbreviations and their literal meanings are listed here: 

ISR = Instruction State register 

OSR = Operand State register 

CIR = Channel Index register 

CR = Condition register 

BCR = BDP Condition register 

PIF = Page Index File 

(Aon-02^ = contents of the lower 3 bits (00, 01, and 02) of the A register 
[ Brl = contents of the index register as defined by the value of the 

Bj. flag. 
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m<n 
m>n 
m>n 
m«n 
(m)-*n 

V 

A 



in "less than" n 

m "greater than" n 

m "greater than or equal to" n 

logical product of m and n 

contents of m, transferred to n 

Exclusive OR function 

AND function 



Instruction Word Formats 

Word oriented instructions are the most common of the instruction formats. 
Fifteen bits are allocated for an unmodified storage address, operand, or shift 
count. Indirect addressing is usually available. Figure 5-1 illustrates a word 
oriented instruction and the significance of the first 15 bits when they represent 
an unmodified word address 'm'. 



17 16 



15 14 



(6 BITS) 


(1 BIT) 


(2 BITS) 


(15 BITS) 


\ /\ A /\ / 


V 


V 


V 


V 



FUNCTION CODE 



Symbol designators 
(See Symbol Definitions) 

Figure 5-1. Word- Addressed Instruction Forniat 

Character oriented instructions allocate 17 bits for unmodified character ad- 
dresses or extended operands. Indirect addressing is not available for these 
instructions; however, address modification is permissible by referencing a 
specific index register. Figure 5-2 illustrates the format of a character 
oriented instruction word and the significance of the first 17 bits when they re- 
present an unmodified character address 'r'. 



23 




18 


17 


16 




00 


16 BITS ) 


(1 BIT) 


( 17 BITS) 


\ 




l\ l\ 




/ 



Characters in a data word are always specified in the following manner; 

23 18 17 12 11 06 05 00 



12 3 



character designators 
Figure 5-2. Character- Addressed Instruction Format 
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Word Addressing/Character Addressing 

It is often desirable to convert a word address and character position to its 
corresponding character address or vice versa. The following procedure is a 
technique used for this purpose. 

To convert a word address to a character address: 

• Octally multiply the word address by four. (During program execution, 
this operation is simulated by a left shift of two binary places, ) 

• Add the character position to the product. 
The sum is the character address. 



EXAMPLE: 

Given: Word address 12442, character position 2 

Find: Corresponding character address 

1. 12442 

x4 



52210 

+2 



52212 = character address 

To convert a character address to a word address: 

• Octally divide the character address by four 

The quotient is the word address and the remainder is the character position. 
No remainder indicates character zero. 

EXAMPLE: 

Given: Character address 03442 

Find: Word address and character position 

00710 
JJ03442 

4 

2 = remainder = character position 2 

NOTE 

Octal multiplication and division tables may be found in 
Appendix C of this manual. 

Instruction word formats that differ from word and charac- 
ter orientation are described in the instruction listing. 

Business oriented instructions require three instruction words to completely 
define an operation. These instructions are executed only by the BDP. These 
subinstruction words are always located at consecutive memory locations, 
nominally designated P, P+1, and P+2. 

5-5 Rev. A 



I 

17 16 



I FOR DELIMITING WHEN AVAILABLE 



(6 BITS) 


(1 BIT) 


(17 BITS) 



FUNCTION CODE 
23 2! 20 19 18 17 16 



r OR m (15 BITS) 



P+l (3 BITS) (2 BITS) (2 BITS) 



(17 BITS) 



SUB-FCN Br OR Bm BsORBn 



S OR m OR n (15 BITS) 



00 



Wa 






6^ 



( 6 BITS ) 



DC 



I 
I 



— v— 

S2 



^ 



( 8 BITS ) 



-y— 

DC 



(6 BITS) 



^ 



sc 



OR 



( 6 BITS ) 



(6 BITS ) 



"Ar- 
se 



-y— 
DC 



Figure 5-3. Business Orienteci Instruction Format 



Indexing and Address Modification 

In some instructions, the execution adciress 'm' or 'r', or the shift count 'k' 
may be modified by adding to them the contents of an index register, B^. The 
2-bit designator 'b' specifies which of the three index registers is to be used. 
Symbols representing the respective modified quantities are M, R, and K. 

M = m + (Bt>) 

R = r + (Bb) the sign of B^ is extended to bit 16 (2l'^-l) 

K = k + (Bb) 

In each case, if b = 0, then M = m, R = r and K = k. 
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Special index considerations apply to BDP instructions where an index register 
flag is present. A flag defines which index register is used for indexing: 

EXAMPLE: 

If s = 00413, Bs = 2, and (B^ = 00364, then S = s + [ Bg] or "the 
modified address 'S' equals the unmodified address 's' added to the 
contents of the index register as defined by Bg". 

Thus: 

S = s + [Bs] 
S = 00413 + (b2) 
S = 00413 + 00364 
S = 00777 

Some BDP instructions, i.e. , PAK, CVBD, DTA, etc. utilize both word and 
character addresses in their formats. Although the first two bits preceding the 
address are unused and not part of the word address, the lower 15 bits of this 
word are added to the contents of the specified index register. The lower two 



bits of the specified index register must be set to 
around carry during the index addition. 



'I's to allow for an end- 



EXAMPLE: 



02 0100 



^ 



CBj^] are added to 
the first 15 bits 



Addressing Modes 

Three modes of addressing are used in the computer: 
dress, and Indirect Address. 



No Address, Direct Ad- 



No Address 

This mode is used when an operand 'y' or a shift count 'k' is placed directly in- 
to the lower portion of an instruction word. Symbols 'a' and 'b' are not used as 
addressing mode and index designators with any of the no address instructions. 

Direct Address 

The direct addressing mode is used in any instruction in which an operand ad- 
dress 'm' is stored in the lower portion of the initial instruction word. This 
mode is specified by making 'a' equal to 0. In many instructions, address 'm' 
may be modified (indexed) by adding to it the contents of register B", M = m + 
(Bb). 
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Indirect Address 

It is possible to use indirect addressing only with instructions that require an 
execution address 'm'. For applicable instructions, indirect addressing is 
specified by making 'a' equal to 1, Several levels (or steps) of indirect addres- 
sing may be used to reach the execution address; however, execution time is 
delayed in direct proportion to the number of steps. The search for a final ex- 
ecution address continues until 'a' equals 0. It is important to note that direct 
or indirect addressing and address modification are two distinct and indepen- 
dent steps. In any particular instruction, one may be specified without the 
other. Figure 5-4 shows the indirect addressing routine. 




ORIGINAL 
INSTRUCTION 

POSSIBLY 

CONTAINING 

'a' AND/OR 'b' 



GO TO ADDRESS M. 

ACQUIRE NEW 
TERMS a,b, AND m 



NO 



b = 0? 



YES / \ 

*{ °=o?} 



YES 



NO 



EXECUTE 
INSTRUCTION 

USING 
ADDRESS M 




ADD THE 
(B^) TO m 



Figure 5-4. Indexing and Indirect Addressing Routine Flow Chart 

NOTE 

Unless it is otherwise stated, indirect addressing follows the 
above routine throughout the list of instructions. 



Rev. A 



5-8 



Indexing and Indirect Addressing Examples 

The following examples utilize the LDA (20) instruction; however, the process 
applies to any of the instructions with an 'a' and/or 'b' designator. 

EXAMPLE 1: 

(ADDRESS MODIFICATION - (indexing) ONLY) 

P = 00000 



1 

20 2 54430 




(b2) = 


13342 


/\ 


^ 9 
Add this address to (B^) 




Indicates Direct Address 




mode and address modification 


V 

54430 




by b2 






+13342 





20 2 67772<— Thig address is replaced^— 67772 
temporarily in the 
original instruction 

LDA with the 24-bit quantity stored at address 67772 

67771 

P = 67772 77700000 »This quantity is loaded into the A register 

67773 



EXAMPLE 2: 



(INDIRECT ADDRESSING ONLY) 



P = 00001 20 4 54430 

t 



V 



Indicates Indirect Addressing Go to this address and acquire 

mode but no address modification new address and designator be- 
(indexing). fore executing instruction. 



54427 

-^54430 31 ,0 77111. 

54431 --rrrY== ^ 



This portion of operand is replaced temporarily 
in the original instruction. 



20 77111 



Indicates Direct Address mode and no address modification. LDA 
with the 24-bit operand stored at address 77111. (If this digit would 
have indicated additional indirect addressing and/or address modifi- 
cation this must be done before the LDA instruction is executed. ) 
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EXAMPLE 3: 



(INDIRECT ADDRESSING AND ADDRESS MODIFICATION) 



00002 



20 5^54430^ 
t 
Indicates Indirect Address 
mode and address modifica- 
tion by b1. 



(B-") = 00512 



Add this address to (B-'-). 

54430 
+00512 



55142 

t 
Go to this address and 
acquire new address 
and designator before 
executing instruction. 



55141 

■^55142 

55143 



77,03 7777, 
— V ' 



This portion of operand is replaced temporarily in 
the original instruction. 



20 37777 

t 
Indicates direct address mode and no address modi- 
fication, LDA with the 24-bit operand stored at ad- 
dress 3 7777, (If this digit would have indicated ad- 
ditional indirect addressing and/ or address modifi- 
cation, this must be done before the LDA instruc- 
tion is executed. ) 
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Trapped Instructions 

Certain instructions are trapped if the optional hardware module, necessary 
for their direct execution, is not present in the system. These instructions, 
and the routine followed in processing trapped instructions, are described in 
Section 4. 



INSTRUCTION LIST 

Each group of instructions is introduced with an index, and whenever necessary, 
a group description. Individual instructions are all presented in the same basic 
format: 

Heading, which includes the assembly language mnemonic and 
instruction name or function. 

Machine code instruction format. 

Parameters and their descriptions. 

Instruction description. 

Comments (when necessary). 

The instructions are grouped into general functions, i.e.. Loads, Stores, 
Arithmetic, etc., and the groups are arranged according to the complexity of 
their functions. This arrangement permits a programmer, unfamiliar with the 
instruction list, to progress through this Section with relative ease. 

The abbreviation, RNI, is used throughout the list of instructions to indicate 
the Read Next Instruction sequence. This is a sequence of steps taken by the 
control section to advance the computer to its next program step. For an ex- 
tensive description of this sequence, consult the 3 300 Customer Engineering 
Manual. 

Table 5-1 identifies the instructions by mnemonic and indicates on which page 
detailed instruction descriptions may be found.* Table 5-2 is a summary of the 
instruction execution times. In addition to these tables, additional tables are 
provided at the end of this manual for cross reference of the instruction list. 



The letter "l" after a mnemonic code in Table 5-1 as well as in each group of 
instructions, and in the mnemonic and octal listings in the last section of this 
manual, indicates that indirect addressing may be used for that instruction. 
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TABLE 5-1, INSTRUCTION SYNOPSIS AND INDEX 



Mnemonic 



Instruction 



Page No. 



ACI 
ACR 
ADA, I 
ADAQ, I 

ADM 
AEU 
AIA 
AIS 

ANA 
ANA, S 

ANI 
ANQ 
ANQ, S 

AOS 
APF 
AQA 
AQE 
AQJ, EQ 
AQJ, NE 

AQJ, GE 
AQJ, LT 
ASE 
ASE, S 
ASG 
ASG, S 
ATD 
ATD, DC 

AZJ, EQ 
AZJ, NE 

AZJ, GE 
AZJ, LT 



Transmit (A) to CIR 

Transmit (A) to CR 

Add to A 

Add to AQ 

Add field A to field C 

Transmit (A) to Eu 

Transmit (A) + (B^) to A 

Transmit (A) to ISR 

Logical product (AND) of y and (A) 

Logical product (AND) of y and (A) , sign ex- 
tended 

Logical product (AND) of y and (b'^) 

Logical product (AND) of y and (Q) 

Logical product (AND) of y and (Q) , sign ex- 
tended 

Transmit (A) to OSR 

Transmit (Aqq-h) to PIP 

Transmit (A) + (Q) to A 

Transmit (AQ) to E 

jump if (A) = Q 



Compare A with Q 



jump if (A) 4 Q 



jump if (A) > Q 
jump if (A) < Q 

Skip next instruction, if (A) = y 

Skip next instruction if (A) = y, sign extended 

Skip next instruction if (A) > y 

Skip next instruction if (A) > y, sign extended 

Translate ASCII to BCD 

Translate ASCII to BCD, delimiting character 
possibility 

jump if (A) = 

jump it (A) 4 

jump if (A) > 
jump if (A) < 



Compare A with zero< 



> 



5-38 
5-40 
5-60 
5-61 
5-68 
5-36 
5-33 
5-37 
5-73 

5-73 
5-73 
5-74 

5-74 
5-37 
5-39 
5-32 
5-36 



5-46 



5-29 
5-29 
5-30 
5-30 
5-119 

5-120 



5-45 
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TABLE 5-1. INSTRUCTION SYNOPSIS AND INDEX (Cont'd) 



Mnemonic 



Instruction 



Page No. 



CIA 

CILO 

CINS 

CLCA 

CMP 

CMP, DC 

CON 

COPY 

CPR, I 

CRA 

CTI 

CTO 

CVBD 

CVDB 

DINT 

DTA 

DTA, DC 

DVA, I 
DVAQ, I 
EAQ 
ECHA 
ECHA, S 

EDIT 

EINT 

ELQ 

ENA 

ENA, S 

ENI 

ENQ 

ENQ, S 

EUA 

EXS 



Transmit (CIR) to A 

Channel interrupt lockout 

Copy internal status 

Clear channel activity 

Compare field A with field C, exit if 'f 

Compare field A with field C, exit if j^, delimit- 
ing character possibility 

Connect 

Copy external status 

Within limits test 

Transmit ( CR) to A 

Set console typewriter input 

Set console typewriter output 

Convert binary to BCD 

Convert BCD to binary 

Disable interrupt control 

Translate BCD to ASCII 

Translate BCD to ASCII, delimiting character 
possibility 

Divide AQ (48 by 24) 

Divide AQE (96 by 48) 

Transmit (E^) to A and (E^^) to Q 

Enter A with 17 bit character address 

Enter A with 17 bit character address, sign 
extended 

Edit field A, move to field C 

Enable interrupt control 

Transmit (El) to Q 

Enter A 

Enter A, sign extended 

Enter index 

Enter Q 

Enter Q, sign extended 

Transmit (Ey) to A 

Sense external status 



5-38 
5-91 
5-86 
5-94 
5-79 

5-80 

5-95 

5-83 

5-77 

5-40 

5-97 

5-97 

5-116 

5-115 

5-89 

5-117 

5-118 

5-62 

5-63 

5-36 

5-26 

5-26 

5-149 

5-89 

5-36 

5-25 

5-25 

5-25 

5-25 

5-25 

5-36 

5-83 
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TABLE 5-1, INSTRUCTION SYNOPSIS AND INDEX (Cont'd) 



Mnemonic 


Instruction 


Page No. 


FAD, I 


Floating add to AQ 


5-65 


FDV, I 


Floating divide AQ 


5-66 


FMU, I 


Floating multiply AQ 


5-66 


FRMT 


Formatted edit of field A, move to field C 


5-147 


FSB, I 


Floating subtract from AQ 


5-65 


HLT 


Unconditional halt; read next instruction from 






location m 


5-24 


lAI 


Transmit (B^) + (A) to B^ 


5-33 


lAPR 


Interrupt associated processor 


5-113 


IJD 


Index jump; decrement index 


5-44 


IJI 


Index jump; increment index 


5-43 


INA 


Increase A 


5-27 


INA, S 


Increase A, sign extended 


5-27 


INAC, INT 


Character-addressed input to A 


5-106 


INAW, INT 


Word-addressed input to A 


5-107 


INCL 


Clear interrupt 


5-89 


INI 


Increase index 


5-27 


INPC,INT,B^,G 


Character-addressed input to storage 


5-98 


INPW,INT,B,N,G 


Word-addressed input to storage 


5-100 


INQ 


Increase Q 


5-27 


INQ, S 


Increase Q, sign extended 


5-27 


INS 


Sense internal status 


5-85 


INTS 


Sense interrupt 


5-84 


lOCL 


Clear I/O, typewriter, and S/M 


5-94 


ISA 


Transmit (ISR) to A 


5-37 


ISD 


Index skip; decrement index 


5-31 


ISE 


Skip next instruction if y = 


5-28 


ISE 


Skip next instruction if (B ) = y 


5-28 


ISO 


Skip next instruction if y > 


5-30 


ISG 


Skip next instruction if (B ) > y 


5-30 


ISI 


Index skip; increment index 


5-31 
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TABLE 5-1. INSTRUCTION SYNOPSIS AND INDEX (Cont'd) 



Mnemonic 


Instruction 


Page No. 


JAA 


Transmit jump address to A 


5-40 


JMP, HI 


Jump if BDP register > or + 






JMP, ZRO 


Jump if BDP register = 


> 


5-42 


JMP, LOW 


Jump if BDP register < or - , 






LACH 


Load A character 


5-49 


LBR 


Load BDP Condition register 


5-155 


LCA,I 


Load A complement 


5-50 


LCAQ, I 


Load AQ complement (double precision) 


5-51 


LDA, I 


Load A 


5-49 


LDAQ, I 


Load AQ (double precision) 


5-50 


LDI, I 


LoS^d index 


5-52 


LDL, I 


Load logical 


5-50 


LDQ,I 


Load Q 


5-51 


LPA, I 


Logical product with A 


5-73 


LQCH 


Load Q character 


5-52 


MEQ 


Masked equality search 


5-75 


MOVE, INT 


Move (S) characters from r to s 


5-138 


MTH 


Masked threshold search 


5-76 


MUA, I 


Multiply A 


5-62 


MUAQ, I 


Multiply AQ 


5-63 


MVBF 


Move and blank fill 


5-142 


MVE 


Move 


5-140 


MVE, DC 


Move, delimiting character possibility 


5-141 


MVZF 


Move and zero fill 


5-143 


MVZS 


Move and zero suppress 


5-144 


MVZS, DC 


Move and zero suppress, delimiting character 
possibility 


5-145 


OSA 


Transmit (OSR) to A 


5-37 


OTAC, INT 


Character-addressed output from A 


5-109 


OTAW, INT 


Word- addressed output from A 


5-110 


OUTC, INT, B, H 


Character-addressed output from storage 


5-102 


OUTW, INT, B,N 


Word- addressed output from storage 


5-104 


PAK 


Pack 6 bit BCD characters into 4 bit BCD 
characters 


5-121 
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TABLE 5-1. INSTRUCTION SYNOPSIS AND INDEX (Cont'd) 



Mnemonic 


Instruction 


Page No. 


PAUS 


Pause 






5-87 


PFA 


Transmit (PFI) to A 






5-39 


PRP 


Priority pause 






5-88 


QEL 


Transmit (Q) to E^ 






5-36 


QSE 


Skip next instruction if (Q) = y 






5-29 


QSE, S 


Skip next instruction if (Q) = y, sign 


extended 


5-29 


QSG 


Skip next instruction if (Q) > y 






5-30 


QSG, S 


Skip next instruction if (Q) > y, sign 


extended 


5-30 


RAD, I 


Replace add 






5-60 


RIS 


Relocate to instruction state 






5-112 


ROS 


Relocate to operand state 






5-112 


RTJ 


Return jump 






5-47 


SACH 


Store character from A 






5-54 


SBA, I 


Subtract from A 






5-61 


SBAQ, I 


Subtract from AQ 






5-61 


SB CD 


Set BCD fault 






5-91 


SBJP 


Set boundary jump 






5-112 


SBM 


Subtract field A from field C 






5-69 


SBR 


Store BDP Condition register 






5-155 


SCA, I 


Selectively complement A 






5-72 


SCAN, LR, EQ, DC 




left to right, stop on 


= 




5-130 


SCAN, LR, NE, DC 
SCAN, RL, EQ, DC 


Scan 


stop on 
right to left, stop on 


f 


Delimiting 
* character 
possibility 


5-132 
5-134 


SCAN, RL, NE, DC 


stop on 


f 




5-136 


SCAN, LR, EQ 




left to right, stop on 


= 




5-129 


SCAN, LR, NE 


Scan 


stop on 


f 




5-131 


SCAN, RL, EQ 




right to left, stop on 


= 




5-133 


SCAN, RL, NE 


stop on 


+ 




5-135 


SCAQ 


Scale AQ 






5-59 
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TABLE 5-1. INSTRUCTION SYNOPSIS AND INDEX (Cont'd) 



Mnemonic 


Instruction 


Page No. 


SCHA, I 


Store 17-bit character address from A 


5-56 


SCIM 


Selectively clear interrupt naask 


5-90 


SDL 


Set destructive load 


5-113 


SEL 


Select function 


5-96 


SFPF 


Set floating point fault 


5-91 


SHA 


Shift A 


5-57 


SHAQ 


Shift AQ 


5-59 


SHQ 


Shift Q 


5-59 


SJl 


Jump if key 1 is set 


5-41 


SJ2 


Jump if key 2 is set 


5-41 


SJ3 


Jump if key 3 is set 


5-41 


SJ4 


Jump if key 4 is set 


5-41 


SJ5 


Jump if key 5 is set 


5-41 


SJ6 


Jump if key 6 is set 


5-41 


SLS 


Selective stop 


5-24 


SQCH 


Store character from Q 


5-55 


SRCE, INT 


Search character equality 


5-125 


SRCN, INT 


Search character inequality 


5-127 


SSA, I 


Selectively set A 


5-72 


SSH 


Storage shift 


5-57 .;: 


SSIM 


Selectively set interrupt mask 


5-90 


STA, I 


Store A 


5-53 


STAQ, I 


Store AQ 


5-54 


STI, I 


Store index 


5-56 


STQ, I 


Store Q 


5-55 


SWA, I 


Store 15-bit word address from A 


5-56 


TAI 


Transmit (A) to B^ 


5-33 


TAM 


Transmit (A) to high speed memory 


5-34 


TIA 


Transmit (B ) to A 


5-33 


TIM 


Transmit (B^) to high speed memory 


5-35 


TMA 


Transmit (high speed memory) to A 


5-34 
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TABLE 5-1. INSTRUCTION SYNOPSIS AND INDEX (Cont'd) 



Mnemonic 


Instruction 


Page No. 


TMAV 


Test memory availability 


5-81 


TMI 


Transmit (high speed memory) to B 


5-35 


TMQ 


Transmit (high speed memory) to Q 


5-34 


TQM 


Transmit (Q) to high speed memory 


5-34 


TST 


Test field A for +, -, 


5-82 


TSTN 


Test field A for nunaeric 


5-82.0 


UCS 


Unconditional Stop 


5-24 


UJP, I 


Unconditional Jump 


5-41 


UPAK 


Unpack 4 bit BCD characters into 6 bit BCD 
characters 


5-122 


XOA 


Exclusive OR y and (A) 




XOA, S 


Exclusive OR y and (A) , sign extended 




XOI 


Exclusive OR y and (b'^) 


5-71 


XOQ 


Exclusive OR y and (Q) 




XOQ, S 


Exclusive OR y and (Q) , sign extended 




ZADM 


Zero and add 


5-146 



No-Operation Instructions 

When an attempt is made to execute one of the following instructions at the 
current execution address, P, the computer recognizes them as No-Operation 
(NO-OP) instructions and advances to the next execution address, P+ 1. In 
mnemonics a No- Operation instruction is written as: NOP. 



NO- 


OPERATION 


OCTAL 


CODES 




02 







14 







15 







16 







17 






During non-Executive mode operation each of the following instructions are re- 
cognized as No- Operation instructions if an attempt is made to execute one of 
them. Also refer to Trapped Instruction processing. Section 4. 



ACI 


ISA 


ROS 


AIS 


JAA 


sbjp 


AOS 


OSA 


SDL 


APF 


PFA 


SRA 


CIA 


RCR 
RIS 


TMAV 
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Instruction Execution Times 

Except for the 64. through 77. 1 instructions, an actual instruction execution 
time consists of the base execution time listed plus the time for an RNI cycle. 
If indexing or indirect addressing is used, their execution times must be added 
to base instruction time. 

Relocation time is added only if the RNI or RADR cycle preceding the RNI or 
RADR currently in progress was in a different memory page or if the ROP or STO 
cycle preceding the ROP or STO in progress was in a different memory page. 
That is, by programming RNI's and RADR's in the same page and ROP's and 
STO's in the same page, relocation processing time can be minimized. 

Table 5-2 is an octal list of all 3300 instructions with their base execution 
times. During certain multiple cycle instructions, it is possible to execute 
other instructions concurrently, thus no additional execution time is required. 

TABLE 5-2. SUMMARY OF INSTRUCTION EXECUTION TIMES. USEC 



Instruction 
Processing Operation 


Time Added to Base 
Execution Time (usee) 


RNI cycle 

Indexing (address modi- 
fication) 

Relocation 

Indirect addressing 


1.3X5 

.375 
.250* 
1.375 



*The time added to base execution time is 0. 150 usee if the Multiprogramming 
Module is present and no relocation is performed. 



yp^e.-*^ 



^ 



^_yn d ^^i-^ 
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TABLE 5 


-2 (Cont'd) 




Basic 




Execution 


Basic 




Execution 


Octal 


Mnemonic 


Time 


Octal 


Mnemonic 


Time 


Code 


Code 


(usee) 


Code 


Code 


(usee) 


00 


HLT 


0.000 


17 


ANI 


0. 000 


00 


SJl-6 


0.000 


17 


ANA 


0.000 


00 


RTJ 


1.375 


17 


ANQ 


0. 000 


01 


UJP 


0.000 


20 


LDA 


1. 375 


02 


IJI 


0. 000 


21 


LDQ 


1.375 


02 


IJD 


0.000 


22 


LACK 


1.375 


03 


AZJ 


0.625 


23 


LQCH 


1. 375 


03 


AQJ 


0. 625 


24 


LCA 


1. 375 


04 


ISE 


0. 625 


25 


LDAQ 


2.625 


04 


ASE 


0.625 


26 


LCAQ 


2. 625 


04 


QSE 


0. 625 


27 


LDL 


1. 375 


05 


ISG 


0. 625 


30 


ADA 


1. 375 


05 


ASG 


0.625 


31 


SBA 


1.375 


05 


QSG 


0.625 


32 


ADAQ 


2.625 


06 


MEQ 


2. 375 + 2.5n 


33 


SBAQ 


2. 625 


07 


MTH 


2. 375 + 2. 5n 


34 


RAD 


2. 625 


10 


SSH 


2. 625 


35 


SSA 


1. 375 


10 


ISI 


0.625 


36 


SCA 


1. 375 


10 


ISD 


0.625 


37 


LPA 


1.375 


11 


ECHA 


0.000 


40 


STA 


1. 375 


12 


SHA 


0.000 to 1.375 


41 


STQ 


1. 375 


12 


SHQ 


0.000 to 1. 375 


42 


SACK 


1. 375 


13 


SHAQ 


0.000 to 1. 375 


43 


SQCH 


1. 375 


13 


SCAQ 


0.875 to 2.250 


44 


SWA 


1.375 


14 


ENI 


0.000 • 


45 


STAQ 


2. 625 


14 


ENA 


0.000 


46 


SCHA 


1. 375 


14 


ENQ 


0.000 


47 


STI 


1. 375 


15 


INI 


0.000 


50 


MUA 


6. 875 to 9. 875 


15 


INA 


0.000 


51 


DVA 


10. 250 


15 


INQ 


0.000 


52 


CPR 


1. 375 to 2. 625 


16 


XOI 


0.000 


53 


TIA 


0.000 


16 


XOA 


0.000 


53 


TAI 


0.000 


16 


XOQ 


0.000 


/53 


TMQ 


0. 625 
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TABLE 


5-2 (Cont'd) 






Basic 




Execution 


Basic 




Execution 


Octal 


Mnemonic 


Time 


Octal 


Mnemonic 


Time 


Code 


Code 


(usee) 


Code 


Code 


(usee) 


53 


TQM 


0. 625 


66 


UPAK 


10.7 + 0. 9S^ 


53 


TMA 


0. 625 


67 


ADM & SBM 


©9+3. 1«+ 0. 75. S2 


53 


TAM 


0. 625 






©13+3. Iwf 1. 65 S5 


53 


TMI 


0. 625 


67 


ZADM 


10.7 + O.9S2 


53 


TIM 


0. 625 


67 


CMP 


10. 7 + 0. 9T 


53 


AQA 


0. 000 


67 


TST 


©9. 4 


53 


AIA 


0. 000 






© 8, 5 + 0. 9 Si 


53 


lAI 


0.000 


67 


TSTN 


©8. 5 +0. 9 Si 


54 
55 


LDI 
RIS 


1. 375 
0.000 


70 
70 
70 


LBR 

JMP 
SBR 


4. 9 
1. 44 
4. 9 


56 


MUAQ 


16. to 19. 


71 


SRCE 


* 


57 


DVAQ 


25.5 


71 


SRCN 


* 


60 


FAD 


4.850 to 6.250 


72 


MOVE 


;'c 


61 


FSB 


4. 850 to 6. 250 


73 


INPC 


* 


62 


FMU 


16.0 


73 


INAC 


> 




63 


FDV 


19.0 


74 


INPW 


5 




64 


MVE 


10. 7 + 0. 9 S 


74 


INAW 


> 


< 


64 


MVBF 


10.7 + 0. 9S2 


75 


OUTC 


' 




64 


MVZF 


12. 9+ 0,9S2 


75 


OTAC 


> 


< 


64 


MVZS 


10. 7+0. 9S2 


76 


OUTW 


> 




64 


FRMT 


10.7 + 0. 9S2 


76 


OTAW 


> 




64 


EDIT 


Q>9+3. 1W+ 0. 75 S2 


77 


CON 


> 








® 13+3. lW+1. 65 S2 


77 


SEL 


> 


c 


65 


SCAN 


8.5 + 0. 9 S2 


77 


EXS 


0.000 


66 


CVBD 


17, 9 + 0. 92 [<* (1+M) + 


77 


COPY 


0. 000 






^M^+8N^+20N2+28N3] 


77 


INS 


0.000 


66 


CVDB 


® 13.7 + 0, 92 (3Ni + 


77 


CINS 


0. 000 






6N2 + 8N3) 


77 


INTS 


0.000 






® 13, 7 + 0. 92(4Ni + 


77 


INCL 


0. 000 






ION2 + I4N3 - 1) 


77 


lOCL 


0.000 








77 


CILO 


0.000 


66 


DTA 


10.7 + 1. 1 S 


77 


CLCA 


0. 000 


66 


ATD 


10.7 + 1. 1 S 


77 


SSIM 


0.000 


66 


PAK 


10.7 -I- 0. 9 S^ 


77 


SCIM 


0. 000 
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TABLE 


5-2 (Cont'd) 




Basic 




Execution 


Basic 




Execution 


Octal 


Mnemonic 


Time 


Octal 


Mnemonic 


Time 


Code 


Code 


(usee) 


Code 


Code 


(usee) 


77 


ACI 


0. 000 


77 


AOS 


0. 000 


77 


CIA 


0.000 


77 


AIS 


0.000 


77 


JAA 


0.000 


77 


OSA 


0. 000 


77 


lAPR 


0.000 


77 


ISA 


0. 000 


77 


PAUS 


0. to 40 ms 


77 


SLS 


0. 000 


77 


PRP 


0. to 40 ms 


77 


SFPF 


0.000 


77 


TMAV 


1. 375 or 6. 375 us 


77 


SBCD 


0.000 


77 


SBJP 


0. 000 


77 


DINT 


0.000 


77 


SDL 


0. 000 


77 


EINT 


0.000 


77 


CRA 


0. 000 


77 


CTI 


* 


77 


ACR 


0.000 


77 


CTO 


?[i 


77 


APF 


0. 000 


77 


ucs 


0. 000 


77 


PFA 


0. 000 









n 

^1 

^2 

M 

Mj 

^2 
^3 

S 
a 



« 



number of characters searched 

number of characters in source field (A) 

number of characters in result field (C) 

number of most significant 4r-bit binary groups (in the lower 24 bits to be 
converted) which have a zero value 

number of most significant 4^bit binary groups (in the upper 24 bits to be 
converted) which have a zero value (see example) 

number of characters up to and including three in number (For the CVBD 
instruction, the term character defines a binary group of 4 bits to the 
right of any consecutive lead groups which are all zero. See example.) 

number of characters from three, up to and including seven in number. 
(See example. ) 

number of characters greater than seven in number (For the CVBD 
instruction, the term character defines a binary group of 4 bits to the right 
of any consecutive lead groups which are all zero. See example. ) 

number of characters in the smaller of fields S^ and Sg- 

If all upper 24 bits to be converted are zero, cc = 1; if not a = 0. 

If one or more of the upper 24 bits to be converted is a "l", 3 = 1, if not 
13 = 0. 

number of characters in the longer of fields S^ and So- 

Dependent upon a variable signal response time from an external equipment 
or internal source; i. e. , Block Control, 

niomber of 4 character groups in field S2 ■ 
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© 
© 
© 
© 
© 
© 
© 



best case (no second pass) 

worst case (second pass required) 

best case (no carry propagation) 

worst case (maximum carry propagation) 

worst case (maximum carry propagation and second pass required) 

best case (field ?^ zero) 

worst case (entire field = zero) 



SPECIAL PARAMETER EXAMPLES 



(M) 



M]^ = 2 in this case 
23 20 19 16 15 12 11 08 07 04 03 00 









5 


6 


7 


3 



V — 

N3 

N3 = 3 



No 



(M+ 1) 




23 20 14 16 15 12 11 08 07 04 03 00 



2 


1 


3 





4 


5 



N. 



-/\_ 



-V- 

N, 



N2 = 4 



Ni 



Data words are divided into six 4 -bit groups internally by the CPU and are shown here 
only to illustrate the parameters necessary for determining the instruction execution 
time. 
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Halt and Stop Instructions 



Operation Field 


Address Field 


Interpretation 


HLT 00 

SLS 77 
UCS 77 


m 


Halt 

Selective stop 
Unconditional stop 



HLT 
Half 



18 17 15 14 



00 





m 



Instruction Description: Unconditionally halt at this instruction. Upon restart- 
ing, RNI from address m. 

Comments: Indirect addressing and address modification may not be used. 



SLS 
Selective Stop 



zz 


18 


17 


12 


II 


00 


77 


70 


Mm^y 


'WM^. 



Instruction Description: Program execution halts if the SELECT STOP switch 
on the console is set. RNI from address P + 1 upon restarting. 

Comments: Bits 00 through 11 should be loaded with zeros. 



UQS 
Unconditional Stop 



23 




18 


17 




12 


II 


00 


77 


77 


Wi^M'. 


Wi^Hi^i 



Instruction Description: This instruction unconditionally stops the execution of 
the current program. RNI from address P + 1 upon restarting. 

Comments: Bits 00 through 11 should be loaded with zeros. 
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Enter Instructions 



Operation 


Field 


Address Field 


Interpretation 


ENI 


14 


y.b 


Enter index b with y 


ENA 


14 


y 


Enter A with y 


ENA, S 


14 


y 


Enter A with y and extend sign of y 


ENQ 


14 


y 


Enter Q with y 


ENQ,S 


14 


y 


Enter Q with y and extend sign of y 


ECHA 


11 


z 


Enter A with z 


ECHA, S 


11 


z 


Enter A with z and extend sign of z 



ENI 
Enter Index with y 



18 17 16 15 14 



14 





b 


y 



b = index register designator 
Instruction Description: Clear index register B and enter y directly into it. 
Comments: If b = 0, this is a no- operation instruction. 



ENA 
Enter A with y 



14 


6 


y 



Instruction Description: Clear the A register and enter y directly into A. 



ENA, S 
Enter A with y, 
Sign Extended 



18 17 15 14 



14 


4 


y 



Instruction Description: Same as ENA except the sign of y is extended. 



ENQ 
Enter Q with y 



1817 1514 



14 


7 


y 



Instruction Description: Clear the Q register and enter y directly into Q. 



ENQ, S 
Enter Q with y. 
Sign Extended 



18 17 15 14 



14 


5 


y 



Instruction Description: Same as ENQ except the sign of y is extended. 



5-25 



Rev. F 



^CHA 23 18 17 16 

Enter Character 
Address into A 



II 





z 



Instruction Description: Clear A; then enter a 1 7-bit operand z (usually a 

.... ----- 3^ • . " 



character address) into A. 



ECHA, S 23 18 1716 00 

Enter Character 
Address into A, Sign Extended 



Instruction Description: Clear A; then enter a 24-bit operand (17-bit z plus 
7 bits of sign extension) into A. 



1 1 


1 


z 



NOTE 

If is often desirable to perform operations with the A or Q registers 
using a negative operand. By using the sign extension feature of cer- 
tain instructions, 14-bit negative operands become available. This 
feature eliminates the need, in many instances, to reference prestored 
operands. 

The following examples illustrate the use of sign extension in some instructions: 

EXAMPLE A: To enter negative zero into Q, execute a 14 5 77777. 

EXAMPLE B: To increase (A) by -17, execute a 15477760 instruction. 

(A) = 00066667 (arbitrary value) 
77777760 
00066647 

(end around carry) 1 

00066650 =(A) after instruction-execution 

In all cases of sign extension, bit 14 for 15-bit y operands and bit 16 for 17-bit 
z operands determines the sign of the quantity. 
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Increase Instructions 



Operation 


Field 


Address Field 


Interpretation 


INI 


15 


y,b 


Increase index by y 


INA 


15 


y 


Increase A by y 


INA, S 


15 


y 


Increase A by y, sign extended 


INQ 


15 


y 


Increase Q by y 


INQ, S 


15 


y 


Increase Q by y, sign extended 



INI 
Increase Index by y 



23 



18 1716 15 14 



00 



1 '= 





b 


y 



b = index register designator 
Instruction Description: A dd y to (B ). 

Comments: If b = 0, this is a no- operation instruction. Signs of y and B are 
extended. 



INA 
Increase A by y 



23 



1817 15 14 



00 



15 


6 


y 



Instruction Description: Add y to (A). 



1NA,S 

Increase A by y. 

Sign Extended 



23 



18 17 15 14 



00 



15 


4 


y 



Instruction Description: Same as INA except the sign of y is extended. 



INQ 
Increase Q by y 



18 17 15 14 



IS 


7 


y 



Instruction Description: Add y to (Q). 

INQ, S 23 18 17 15 14 

Increase Q by y. 
Sign Extended 

Instruction Description: Same as INQ except the sign of y is extended. 



15 


5 


y 
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Skip Instructions 



Operation Field 



ISE 
ASE 
ASE, S 


04 
04 
04 


QSE 
QSE, S 


04 
04 


ISG 

ASG 
ASG, S 


05 
05 
05 


QSG 
QSG, S 


05 
05 


ISI 
ISD 


10 
10 



Address Field 



y 
y 

y 
y 

y,b 

y 
y 

y 
y 

y.b 
y.b 



Interpretation 



f; 



Skip next instruction if (B ) = y 
Skip next instruction if (A) = y 
Skip next instruction if (A) = y. 
y is extended. 

Skip next instruction if (Q) = y 
Skip next instruction if (Q) = y. 
y is extended, r^ 

Skip next instruction if (B ) > y 
Skip next instruction if (A) > y 
Skip next instruction if (A) > y. 
y is extended. 

Skip next instruction if (Q) > y 
Skip next instruction if (Q) > y. 
y is extended. 
Index skip, incremental 
Index skip, decremental 



Sign of 



Sign of 



Sign of 



Sign of 



NOTE 

The SSH (10, 0) instruction, which also uses 
a Skip exit, is described in the Shift and Scale 
Instruction group. 



ISE 

Skip Nexf 

Instruction if (B") - y 



18 17 16 15 14 



04 





b 


y 



b = index register designator 

Instruction Description: If (B^) = y, skip to address P+2; if not, RNI from ad- 
dress P+1 . 

Comments: If b = 0, y is compared to zero. 
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ASE 
Skip Nexf 
Instruction if (A) y 



18 17 15 14 



04 


6 


y 



Instruction Description: If (A) = y, skip to address P+2; if not, RNI from ad- 
dress P+1 . 

Comments: Only the lower 15 bits of A are used for this instruction. 



ASE, S 
Skip Next 
Instruction if (A) — y, Sign Extended 



18 17 15 14 



04 


4 


y 



Instruction Description: Same as ASE except the sign of y is extended. All 
24 bits of A are recognized. 



QSE 

Skip Next 

Instruction if (Q) = y 



23 



18 17 15 14 



00 



04 


7 


y 



Instruction Description: If (Q) = y, skip to address P+2; if not, RNI from ad- 
dress P+1. 

Comments: Only the lower 15 bits of Q are used for this instruction. 



QSE, S 
Skip Next 
Instruction if (Q) — y. Sign Extended 



18 17 15 14 



00 



04 


5 


y 



Instruction Description: Same as QSE except the sign of y is extended. All 24 
bits of Q are recognized. 
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;sG 

Skip Next 
Instrucfion if (B ') ' y 



23 



18 17 16 15 14 



00 



05 





b 


1 



b = index register designator 



Instruction Description: If (B ) are equal to or greater than y, skip to address 
P+2; if not, RNI from address P+1 . (B°) and y are 15-bit positive numbers. 

Comments: If b = 0, y is compared to zero. 



ASG 

Skip Nexf 

Instruction if (A) ^ y 



00 



05 


6 


. 



Instruction Description: I f (A) are equal to or greater than y, skip to address 
P+2; if not, RNI from address P+1. Only the lower 15 bits of A are used. 

Comments : (Aj^^^) and y are considered 15-bit positive numbers. 



ASC, S 
Skip Next 
Instruction if (A) = y. Sign Extended 



23 




IB 


17 


15 14 




00 


1 " 


4 


y 



Instruction Description: Same as ASG except the sign of y is extended. All 24 
bits of A are recognized. Positive zero (00000000) is recognized as greater 
than negative zero (77777777). 



QSG 

Skip Next 

Instruction if (Q) S y 



18 17 15 14 



D 



Instruction Description: If (Q) are equal to or greater than y, skip to address 
P+2; if not, RNI from address P+1. Only the lower 15 bits of Q are used. 

Comments: (Q-j^-j^g) and y are considered 15-bit positive numbers. 



18 17 15 14 



05 


5 


y 



QSG,S 
Skip Next 
Instruction if (Q) g y. Sign Extended 

Instruction Description: Same as QSG except the sign of y is extended. All 24 
bits of Q are recognized. Positive zero (00000000) is recognized as greater 
than negative zero (77777777). 
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ISI 
Index. Skip, 
Incremental 



23 



18 1716 1514 



,0 





b 


y 



b = index register designator 

Instruction Description: If (B ) = y, clear B and skip to address P+2; if not, 
add one to (B^) and RNI from address P+1. 

Comnaents: The 10.0 instruction is a SSH (storage-«hrft) instruction, described 
later in this section. 



ISI INSTRUCTION 
TRANSLATED 



INCREMENT (6^) 

BY 1 AND 

RNI (5) P + 1 


NO, 


\ 



(Bb)= y ? J 



CLEAR 8" AND 
RNI @ P+2 



ISO 
Index Skip, 
Decremental 



23 



18 17 16 15 14 



10 


1 


b 


y 



b = index register designator 

Instruction Descripti on: If (B ) = y, clear B and skip to address P+2; if not, 
subtract one from (b'-') and RNI from address P+1. 

Comments: When b = 0, RNI from P+1 if y / 0; RNI from P+2 if y = 0, 



ISD INSTRUCTION 
TRANSLATED 



DECREMENT (B^) 

BY 1 AND 

RNI @ P+1 


c '°( 


^ I 



,YES 



(Bt')=y ? 



CLEAR B'' AND 
RNI (35 P+2 
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Inter-Register 


Transfer Instructions 






Operation 


Field 


Address Field 


Interpretation 


AQA 


53 




Transfer (A) + (Q) to A 
Transfer (A) + (B") to A 




AIA 


53 


b 




lAI 


53 


b 


Transfer (Bb) + (A) to B^ 




TIA 


53 


b 


Transfer (B^) to A 




TAI 


53 


b 


Transfer (A) to B^ 




TMQ 


53 


V 


Transfer (Register v) to Q 




TQM 


53 


V 


Transfer (Q) to Register v 




TMA 


53 


V 


Transfer (Register v) to A 




TAM 


53 


V 


Transfer (A) to Register v 




TMI 


53 


v,b 


Transfer (Register v) to B^ 




TIM 


53 


V, b 


Transfer (B^) to Register v 




ELQ 


55 




Transfer (El) to Q 




EUA 


55 




Transfer (Ey) to A 




EAQ 


55 




Transfer (EijEl) to AQ 




QEL 


55 




Transfer (Q) to El 




AEU 


55 




Transfer (A) to Ey 




AQE 


55 




Transfer (AQ) to EyEL 




AIS 


77 




Transfer (A00-02) to ISR 




ISA 


77 




Transfer (ISR) to Aoo-02 




AOS 


77 




Transfer (A00-O2) ^o OSR 




OSA 


77 




Transfer (OSR) to Aoo-02 




ACI 


77 




Transfer (A00-02) to CIR 




CIA 


77 




Transfer (CIR) to Aoo-02 




APF 


77 


w, b 


Transfer (Aqo-II) to PIF location 


'w' 


PFA 


77 


w, b 


Transfer (PIF location 'w') to Aqq- 


■11 


CRA 


77 




Transfer (CR) to Aqo-OS 




ACR 


77 




Transfer (Aoo-05) to CR 




JAA 


77 




Transfer LJA to AoO-14 





AQA 

W + (q;- 




Instruction Description: Add the (A) to the (Q) and transfer the sum to A. 

Comments: (Q) remain unchanged. Bits 00 through 11 should be loaded with 
zeros. 
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A\A 

(A) + (&'')--* A 



18 17 16 15 14 12 II 



00 






b = index register designator 

Instruction Description: Add the (A) to the (B^) and transfer the sum to A. 

Conaments: Bits 00 through 11 should be loaded with zeros. The sign of (B ) is 
is extended prior to the addition. (B ) remain unchanged. 






18 17 16 15 14 12 II 



00 



53 


1 


b 


4 


WM^M!^M^y 



b = index register designator 

Instruction Description: Add the (A) to the (B'-') and transfer the sum to B*^. 

Comments: Bits 00 through 11 should be loaded with zeros. The sign of the 
original (B^) is extended prior to the addition. The upper 9 bits pf the sum are 

lost when the sum is transferred to the Index register. If b=0, this becomes a 

No- Op instruction. 



J\A 

(R^j-A 



IB 17 16 15 14 



b = index register designator 

Instruction Description: Transfer the (B") to A. 

Comments: Bits 00 through 11 should be loaded with zeros. No sign extension on 
B*^. Prior to the transfer, (A) are cleared. If b = 0, zeros are transferred to A. 



JA\ 

(A) -* 8" 



18 17 16 15 14 12 I I 



53 


1 


b 





'^^^iM^MMW^y 



b = index register designator 

Instruction Description: Transfer the (A) to B . 

Comments: Bits 00 through 11 should be loaded with zeros. The (A) remain 
unchanged. If b = 0, this becomes a no-operation instruction. 
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TMQ 
(v)-^Q 



IB 17 16 15 14 12 II 



V = register file number, 00-77, 
Instruction Description: Transfer the (v) to Q. 
Comments: Bits 06 through 11, 15 and 16 should be loaded with zeros. 



TQM 



18 17 16 15 14 12 II 



V = register file number, 00-77 
Instruction Description: Transfer the (Q) to v. 
Comments: Bits 06 through 11, 15 and 16 should be loaded with zeros. 



8 



TMA 



23 



18 17 16 15 14 12 II 



00 



53 





'M 


2 


W^M!/. 


V 



V = register file number, 00-77„ 
Instruction Description: Transfer the (v) to A. 
Comments: Bits 06 through 11, 15 and 16 should be loaded with zeros. 



(A) -v 



18 17 16 15 14 12 II 





y/A 




'////y 






53 


1 


%^ 


2 


^'^ 


W/YA 


V 



V = register file number, 00-77o 
Instruction Description: Transfer the (A) to v. 
Comments: Bits 06 through 11, 15 and 16 should be loaded with zeros. 



Kev. A 



5-34 



TMI 
(v) 'B- 



18 17 16 15 14 12 II 



00 



53 





b 


3 


WiM>. 


V 



b = index register designator 
V = register file number, 00-77o 

Instruction Description: Transfer the lower 15 bits of (v) to B^. 

Comments : Bits 06 through 11 should be loaded with zeros. If 'b' = 0, this 
becom.es a no -operation instruction. 






23 



18 17 16 15 14 12 II 



06 05 



00 



53 


1 


b 


3 


'WM^. 


V 



b = index register designator 
V = register file number, 00-77„ 



Instruction Description: Transfer (B^) to v. The upper nine bits of 'v' are cleared. 

Comments : Bits 06 through 11 should vbe loaded with zeros. If 'b' = 0, all of 
(v) are cleared. 
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ELQ 
(E.)-Q 




Instruction Description: Transfer the (E^ ) to Q. Bits 00-14 should be loaded 
with zeros. 



EUA 
(E.) -A 



23 18 17 15 14 



00 



m 



Instruction Description: Transfer the (E^J to A. Bits 00 - 14 should be loaded 
with zeros. 



EAQ 

(E)^AQ 



23 18 17 15 14 



00 



55 


3 


WMM^MMM^ 



Instruction Description: Transfer the (E^^E ) to AQ. Bits 00 - 14 should be 
loaded with zeros. 



QEl 

(Q)^E, 



23 18 17 15 14 



00 



55 


5 


'WMMMMM^ 



Instruction Description : Transfer the (Q) to E^ . Bits 00-14 should be loaded 
with zeros. 



AEU 

{A)-^ E, 



23 18 17 15 14 



Instruction Description: Transfer the (A) to E^,. Bits 00 - 14 should be loaded 
with zeros. 



AQE 

(AQ)^E 



23 18 17 15 14 



^ 



Instruction Description: Transfer the (AQ) to E^,E, . Bits 00-14 should be 
loaded with zeros. 
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AIS 
(A.^,J - . ISR 



23 1817 1211 0908 



77 


66 


4 


000 



Instruction Description : Transfer (A , ., „„ ^^ d 02^ *° ^^^ Instruction 
State register. ' ' 



ISA 
(ISR)-> A„ 



23 18 17 \Z II 09 08 



" 


67 


4 


1 



Instruction Description: Transfer (ISR) to A^^.^^ 00^ 0^^ and 02)" 



AOS 

(^00 02/ \J^K 



23 




1817 




121 1 




00 


77 


66 


0000 



Instruction Description: Transfer (A^^^^ qq ^^ nd 02^ *° ^^^ Operand State 

X t.gJ.D Lei • 



OSA 
(OSR)~^A^.,, 



23 18 17 12 II 



00 



" 


67 






Instru ction Description: Transfer (OSR) to A,,., „n m j no\. 
(bits 00, 01, and 02) 
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ACI 

CA,, „j--c;r 



77 


54 


WM^MM^A 



Instruction Description: Transfer (A, ., „r, ^^ 

=—7 bits 00, 01, 

register. 



and 02 



) to the Channel Index 



Comments : Bits 00 through 11 should be loaded with zeros. This instruction is 
used to set the CIR to a value from to 7. When referenced, (CIR) are logically 
OR'ed with the channel designator, ch, in the following instructions: 



73 through 76 I/O instructions 

77.0 Connect 

77. 1 Select Function 

77.2 Sense External Status 



77.2 Copy External Status 

77.3 Sense Internal Status 

77.3 Copy Internal Status 

77.4 Sense Interrupt 



C/A 



23 




18 17 




12 1 1 


00 


77 


55 


WMi^A 


WM^y 



Instruction Description: Transfer (CIR) to A,, ., ^^ „„>. 
Comments: Bits 00 through 11 should be loaded with zeros. 
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77 


\ 
64 


b 


y////// 


w 



b = index designator, B only 



Inst ruction Description: Transfer (A,., „„ xi in 

Page Index File address 'w ^^^^ 0° through 11 



) to the 12 -bit index at 



'w' 



Comments : If bit 11 is a "l", (B ) are used for address modification. Bits 07 
through 10 should be loaded with zeros. This instruction is a no-operation 
instruction if the 3 311 Multiprogramming option is not present in the system. 



P?A 

(PIF)^Aoo.u 



12 II 10 



77 


65 


b 


^^ 


W 



b = index designator, B only 

Instruction Description: Transfer the 12-bit index at Page Index File address 
'w' to A^^.^g QQ through 11). 

Comments: If bit 11 is a "l", (B ) are used for address modification. Bits 07 
through 10 should be loaded with zeros. This instruction is a no-operation 
instruction if the 3311 Multiprogramming option is not present in the system. 
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CRA 
(CR) * Aooos 



23 



12 II 



0000 



3 



I nstruction Description : Transfer the (CR) to the lower 6 bits of A. 
Condition register is cleared upon completion of the transfer. 



The 



Comments: This instruction should be used in interrupt routines during Exec- 
utive Mode operations. All interrupts are disabled between interrupt recognition 
and the execution of the instruction. Program conditions represented by the 
Condition register are listed below: 

Bit 00 - Boundary Jump 

Bit 01 - Destructive Load A 

Bit 02 - Operand Relocation Using OSR 

Bit 03 - Program State Jump 

Bit 04 - Interrupt System Enabled 

Bit 05 - Program State 



ACR 

fAo„.o.>-^CR 



12 II 09 08 



Z3 



Instruction De scription: 



Transfer the (Aqq.q^) 



to the Condition register. 



Comments- This instruction should be used at the end of interrupt routmes 
during Executive mode to restore the Condition register to its original state. 
All interrupts are disabled between the execution of the ACR instruction and the 
iump instruction used to exit from interrupt routines. Refer to the CRA 
instruction for the conditions represented in the Condition register. 



JAA 
Jump Address - 



23 




18 


17 




12 


II 


00 


77 


56 


WM^y 





Instruction Description: Transfer the address, 
struction occurring in Program State, to A 



P, of the last jump type of in- 
(bits 00 through 14). 



Comments: The LJA (Last Jump Address) can also be displayed on the console 
when the LJA switch is depressed and the computer is stopped (refer to Section 
7). Bits 00 through 11 should be loaded with zeros. 
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Jump Instructions 



Operation Field 


Address Field 


Interpretation 


SJl-6 


00 


m 


Jump if appropriate key (1-6) is set 


UJP, I 


01 


m, b 


Unconditional jump 


JMP, HI 


70 


m 


Jump on Positive result 


JMP, ZRO 


70 


m 


Jump on Zero result 


JMP, LOW 


70 


m 


Jump on Negative result 


IJI 


02 


m, b 


Index jump; Incremental index 


IJD 


02 


m, b 


Index jump; Decremental index 


AZJ 


03 


m 


Compare A with zero for Jump condition 


AQJ 


03 


m 


Compare A with Q for Jump condition 


RTJ 


00 


m 


Return jump 



SJl-6 
Selecfive Jump 



18 17 15 14 



00 


j 


m 



j = jump keys 1 to 6 
m = jump address 

Instruction Description : Jump to address m if Jump key j is set; otherwise, 
RNI from address P+1. 

Comments : Indirect addressing and address modification may not be used. 



INSTRUCTION IN F 



RNI FROM 

ADDRESS 

P+ I 



NO 



JUMP KEY 
j SET ? 



YES 



JUMP TO 
ADDRESS m 



UJP 
Unconditional Jump 



18 17 16 15 14 



01 





b 


m 



a = addressing mode designator 
b = index register designator , 
m = storage address; M = m + (B ) 



Instruction Description : Unconditionally jump to address M. 
Comments : Indirect addressing and indexing may be used. 
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JMP, ZRO 
Jump if result ■ 



18 17 15 14 



70 


1 


m 



m = jump address 

Instruction Description : Sense the status of the BCR (BDP Condition Register). 
If the resxilt from the preceding BDP operation was zero, jump to address m. 

Comments : If the console BDP switch is not active or if the BDP is not present 
in the system, this instruction is trapped. (Refer to Section 4.) 



JMP, HI 
Jump if result is + or high 



18 17 15 14 



70 





m 



m = jump address 

Instruction Description : Sense the status of the BCR (BDP Condition Register). 
If the result from the preceding BDP operation was positive or greater than 
zero, jump to address m. 

Comments : If the console BDP switch is not active or if the BDP is not present 
in the system, this instruction is trapped. (Refer to Section 4.) 



JMP, LOW 
Jump if result is — or low 



IB 17 15 14 



00 



70 


z 


. 



m = jump address 

Instruction Description : Sense the status of the BCR (BDP Condition Register), 
if the result from the preceding BDP operation was negative or less than zero, 
jump to address m. 

Comments : If the BDP is not in the system, or the console BDP switch is not 
active, this instruction is trapped. (Refer to Section 4.) 
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IJl 

Index Jump, Incremental 



18 17 16 15 14 



02 





b 


m 



b = index register designator 
m = jump address 

Instruction Description : If b = 1, 2, or 3, the respective Index register is ex- 
amined: 

1. If (B ) = 00000, the jump test condition is not satisfied; RNI from address 
P+1. 

2, If (B^) ?S 00000, the jump test condition is satisfied. One is added to (b'^); 
jump to address m and RNI. 

Comments : If b = 0, this is a No- Operation instruction; RNI from address 
P+1. Indirect addressing and jump address modification may not be used. The 
counting operation is done in a one's complement additive accumulator. Negative 
zero (77777) is not generated because the count progresses from: 77775, 77776, 
to 00000 (positive zero) and stops. If negative zero is initially loaded into Bb, 
the count progresses: 77777, 00001, 00002, etc. In this case, the counter must 
increment through the entire range of numbers to each positive zero. 





YES 


INSTRUCTION IN F 








RNI FROM 

ADDRESS 

P-t- 1 


r 


( b=o? ) 


YES 


1| 




/ 


\ 


NO 




(Bb)= ? j 






( 




1 


NO 




ADD ONE 
TO (b'') 




" 


f 




JUMP TO 

ADDRESS W-, 

RNI 
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UD 
Index Jump, Decremental 



18 17 16 15 14 



00 



02 


1 


b 


1 



b = index register designator 
m = jump address 

Instruction Description : If b = 1, 2, or 3, the respective Index register is ex- 
amined: 

1. If (B^) = 00000, the Jump Test condition is not satisfied; RNI from address 
P+1. 

2. If (B^) f 00000, the Jump Test condition is satisfied. One is subtracted 
from (Bt>); jump to address m and RNI. 

Comments : If b = 0, this is a no- Operation instruction; RNI from address 
p+1. Indirect addressing and jump address modification may not be used. If 
negative zero (77777) is initially loaded into Bb, the count decrements through 
the entire range of numbers to reach 00000 before the program will RNI from 
P+1, 





YES 

- 


INSTRUCTION IN F 




' 




RNI FROM 

ADDRESS 

P+1 


' 


{ ^-or ) 


* 

YESj 


1 


NO 


i 


\ 


' 




(Bb)= ? ) 






\ 


s. " / 




1 


NO 




SUBTRACT ONE 
FROM (Bb) 




) 


f 




JUMP TO 

ADDRESS W-, 

RNX 
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Condition Compare 
A with Zero, Jump 



23 


18 17 16 15 


14 




00 


03 





J 


m 



j = jump designator (0-3) 
m = Jump address 

Instruction Description : The operand in A is algebraically compared with zero 
for an equality, inequality, greater-than or less-than condition (see table). 
If the test condition is satisfied, program execution jumps to address m. If the 
test condition is not satisfied, RNI from address P+1. 

Comments : Positive zero (00000000) and negative zero (77777777) give identi- 
cal results when j = or 1. When j = 2 or 3, negative zero is recognized as 
less than positive zero. Indirect addressing and address modification may not 
be used. 



Condition 
Mnemonic 


Jump 
Designator j 


Test Condition 


EQ 
NE 
GE 
LT 



1 
2 
3 


(A) = 
(A) 5^ 
(A) >0 
(A) <0 





NO 


INSTRUCTION IN F 


YES 








> 


f 




RNI FROM 

ADDRESS 

P + 1 


IS TEST CONDITION^ 


JUMP TO 

ADDRESS 'm'; 

RNI 




SATIS 


FIED? J 
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AQJ 

Condifion Compare 

A with Q, Jump 



23 



18 17 16 15 14 



„, 


1 


j 


1 



3 = 0-3 jump designator (0-3) 
m = jump address 

Instruction Description : The quantity in A is algebraically compared with the 
quantity in Q for equality, inequality, greater- than or less-than condition (see 
table). If the test condition is satisfied, program execution jumps to address 
m. If the test condition is not satisfied, RNI from address P+1. 

Comments : This instruction may be used to test (Q) by placing an arbitrary 
value in A for the comparison. Positive and negative zero give identical results 
in this test when j = or 1, When j = 2 or 3, negative zero is recognized as 
less than positive zero. Indirect addressing and address modification may not 
be used. 



Condition 
Mnemonic 


Jump 
Designator j 


Test Condition 


EQ 
NE 
GE 
LT 



1 
2 
3 


(A) = (Q) 
(A) 5t (Q) 
(A) > (Q) 
(A) < (Q) 



XNSTRUCTION IN F 



RNI FROM 

ADDRESS 

P+l 



NO 



'IS TEST CONDITION! 
SATISFIED ? 



YES 



JUMP TO 

ADDRESS 'm'i 

RNI 
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RTJ 
Refurn Jump 



23 



18 17 15 14 



00 


7 


" 



m = jump address 

Instruction Description : The address portion of m is replaced with the return 
address, P+1. Jump to location m+1 and begin executing instructions at that 
location. 

Comments : This instruction should not be used to transfer control from Monitor 
State to Program State. If an RTJ instruction is executed and the Boundary Jump 
flag is set (refer to SBJP instruction), the STO cycle is executed in Monitor State, 
i.e. , address 'P' is stored at address 'm' of the monitor program. Indirect 
addressing and address modification may not be used. An example of an executed 
RTJ instruction is illustrated on the following page. 



INSTRUCTION IN F 



STORE ADDRESS P + I 
IN THE ADDRESS 
PORTION OF (m) 



BEGIN SUBROUTINE 
WITH INSTRUCTION 
AT ADDRESS m + I 





f 


RETURN TO m 
FOR ADDRESS P+ 1 
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CURRENT 
EXECUT 
ADDRESSES] 



EXECUTE THIS INSTRUCTION 

00500 00 7 33444 
( 0050T 
00502 — - 



© 



INSTRUCTION AT M 
IS USUALLY A JUMP 
BACK TO MAIN PROGRAM 
WITH PROGRAM EXECUTION 
COMMENCING AT P+ 1, 00501 



RTJ INSTRUCTION AUTOMATICALLY 
CAUSES ADDRESS OF P+ 1, 0050 I, 
TO BE PLACED IN LOWER 15 BITS 
OF M, 33444, AND EXECUTES THE 
ADDRESS AT M+ I, 33445 



MEMORY 
ADDRESSES 



P 



M 

M + l 
M + 2 






33444 CO 

33445 - 

33446 - 



M+3 33447(01 33444 



LAST INSTRUCTION OF 
SUBROUTINE USUALLY 
CAUSES JUMP BACK TO 
M AND INSTRUCTION 
AT M IS EXECUTED 



RTJ EXECUTION EXAMPLE 
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Load Instructions 



Operation Field 


Address Field 


Interpretation 


LDA, I 20 


m, b 


Load A 


LACH 22 


r,Bl 


Load A, Character 


LCA, I 24 


m, b 


Load A, Complement 


LDL, I 27 


m, b 


Load A, Logical 


LDAQ, I 25 


m, b 


Load AQ 


LCAQ, I 26 


m, b 


Load AQ, Complement 


LDQ, I 21 


m, b 


Load Q 


LQCH 23 


r,B2 


Load Q, Character 


LDI, I 54 


m, b 


Load Index 



LDA 
Load A 



23 



18 17 16 15 14 



20 


a 


b 


m 



a = addressing mode designator 
b = index register designator , 
m = storage address; M = m + (B ) 

Instruction Description : Load A with a 24-bit quantity from the storage address 
specified by M. 

Comments : Indirect addressing and address modification may be used. 

23 18 17 16 00 

LACH 
Load A, Character 



character 
designator 



" 


b 


r 



16 




02 0100 


00000-77777 


0-3 


\ 





















word address 



If b = 1, r is modified by index 

register B^; R = r + (b1). 

If b = 0, r is not modified (r = R), 

Instruction Description : Load bits 00 through 05 of A with the character from 
storage specified by character address R. The A register is cleared prior to 
the Load operation. 

Comments : Indirect addressing may not be used. Characters are specified in 
storage as follows: 23 is 17 1211 oeos 00 



12 3 



character designators 



5-49 



Rev. A 



NOTE 

Since the sign of B is extended during character address modification, 
it is possible to only reference within ± 16, 383. „ characters. 



LCA 
Load A, Complement 



18 17 16 1514 



00 



24 


a 


b 


1 



a = addressing mode designator 
b = index register designator , 
m = storage address; M = m + (B ) 

Instruction Description : Load A with the ones complement of a 24 -bit quantity 
from storage address M, 

Comments : Indirect addressing and address modification may be used. 



LDL 
Load A, Logical 



23 



18 17 16 15 14 



00 



27 


a 


b 


m 



a = addressing mode designator 
b = index register designator 
m = storage address; m=m.+(Bb) 

Instruction Description : Load A with the logical product (the AND function) of 

(Q) and the 24-bit quantity from storage address M. 



LDAQ 
Load AQ 



18 17 16 15 14 



00 



25 


a 


b 


m 



a = addressing mode designator 
b = index register designator , 
m = storage address; M = m + (B ) 

Instruction Description : Load the A and Q registers with the 24-bit quantities 
from addresses M and M+1, respectively. 

Comments : Addresses 77776 and 77777 should be used only if it is desirable to 
have M and M+1 as non- consecutive addresses, since one's complement arith- 
metic is used to form M+1. 
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LCAQ 
Load AQ, Complement 



18 17 16 15 14 



. 


a 


b 


m 



a = addressing mode designator 
b = index register designator , 
m = storage address; M = m + (B ) 

Instruction Description : Load registers A and Q with the complement of the 
24-bit quantities from addresses M and M+1, respectively. 

Comments : Addresses 77776 and 77777 should be used only if it is desirable to 
have M and M+1 as non- consecutive addresses, since one's complement arith- 
metic is used to form M+1, 



LDQ 
Load O 



18 17 16 15 14 



00 





a 


b 


m 



a = addressing mode designator 
b = index register designator , 
m = storage address; M = m + (B ) 

Instruction Description : Load Q with a 24-bit quantity froxn storage address M. 

Comments: Indirect addressing and address modification may be used. 
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LOCH 
Load Q, Character 



18 17 16 



word address 



00 



23 


b 


r 



il6 




02 01001 


00000-77777 


0-3 


\ 






' 





character 
designator 



If b = 1, r is modified by- 
index register B^; R = r + (B^). 
If b = 0, r is not modified (r = R). 

NOTE 



.b . 



Since the sign of B is extended during character address modification, 
it is possible to only reference within + 16, 383. „ characters. 

Instruction Description : Load bits 00 through 05 of Q with the character from 
storage specified by character address R. The Q register is cleared prior to 
the load operation. 

Comments : Indirect addressing may not be used. Characters are specified in 
storage as follows: ^3 is i7 12:1 oe 05 00 
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character designators 



LDI 
Load Index 



18 1716 1514 



00 



54 


a 


b 


1 



a = addressing mode designator 
b = index register designator 
m = storage address (indexing not permit- 
ted) 



Instruction Description : Load the specified index register, B 
15 bits of the operand stored at address m. 



with the lower 



Comments : Indirect addressing may be used but address modification is not 
possible. During indirect addressing only a and m are inspected. Symbol b 
from the initial instruction specifies which index register is to be loaded with 
the lower 15-bits from the storage address. 
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Store Instructions 



Operation Field 



Address Field 



Interpretation 



STA, I 


40 


SACH 


42 


STAQ, I 


45 


STQ, I 


41 


SQCH 


43 


STI, I 


47 


SWA, I 


44 


SCHA 


46 



m, b 
r,B2 
m, b 
m, b 

m, b 
m, b 
m, b 



1 



Store A 

Store A, character 

Store AQ 

Store Q 

Store Q, character 

Store index 

Store 15-bit word address 

Store 17-bit character address 



STA 
S/ore A 



18 17 16 15 14 



40 


a 


b 


m 



a = addressing mode designator 
b = index register designator , 
m = storage address; M = m + (B ) 

Instruction Description : Store (A) at the storage address specified by M. The 
(A) remain unchanged. 
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23 



00 



SACH 
Store A, Character 



« 


b 


r 



16 




02 0100 


00000-77777 


0-3 








/ 






V 

word address 







character 
designator 

If b = 1, r is modified by 
index register B^; R = r + (B^). 
If b = 0, r is not modified (r = R). 

Instruction Description : Store the contents of bits 00 through 05 of the A reg- 
ister in the specified character address. All of (A) and the remaining three 
characters in storage remain unchanged. 

Comments : Indirect addressing may not be used. Characters are specified in 
storage as follows: 
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character designators 



NOTE 



Since the sign of B is extended during character address modification, 
it is possible to only reference within ±16, 383. „ characters. 



STAQ 
Store AQ 



18 17 16 15 14 



45 


a 


b 


m 



a = addressing mode designator 
b = index register designator , 
m = storage address; M = m -f- (B ) 

Instruction Description : Store (A) and (Q) in the storage locations specified by 
address M and M+1, respectively. The (A) and (Q) remain unchanged. 

Comments : Address 77776 and 77777 should be used only if it is desirable to 
have M and M+1 as non- consecutive addresses, since one's complement arith- 
metic is used to form M+1. 



Rev. A 



5-54 



STQ 
Store O 



23 



18 17 16 15 14 



00 



41 


Q 


b 


m 



a = addressing mode designator 
b = index register designator , 
m = storage address; M = m + (B ) 

Instruction Description : Store (Q) at the storage address specified by M. The 
(Q) remain unchanged. 



23 



18 17 16 



00 



SQCH 
Store O Character 



43 


b 


' 



16 




02 0100 


00000-77777 


0-3 


v 




/ 















word address 

character 
designator 

If b = 1, r is modified by- 
index register b1; R = r + (B-'-). 
If b = 0, r is not modified, (r = R). 

Instruction Description : Store the contents of bits through 5 of the Q register 
in the specified character address. All of (Q) and the remaining three charac- 
ters in storage remain unchanged. 

Comments : Indirect addressing may not be used. Characters are specified in 
storage as follows: 

23 18 17 12 11 06 05 00 
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character designators 



NOTE 



,b . 



Since the sign of B is extended during character address modification, 
it is possible to reference only within ± 16, 383. „ characters. 
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STI 
Store Index 



23 



18 17 16 15 14 



47 


a 


b 


m 



a = addressing mode designator 
b = index register designator 
m = storage address (indexing not permit- 
ted) 

Instruction Description : Store the contents of the specified index register, B", 
in the lower 15 bits of storage address m. The upper 9 bits of m and all of 
(B^) remain unchanged. 

Comments : Indirect addressing may be used, but address modification is not 
possible. During indirect addressing only a and m are inspected. The b desig- 
nator from the initial instruction specifies the Index register that will have its 
contents stored. If b = 0, zeros are stored in the lower 15 bits of m. 



SWA 
Sfore Word Address 



23 



18 17 16 15 14 



44 


a 


b 


m 



a = addressing mode designator 
b = index register designator 
m = storage address; (M = m + (B ) 

Instruction Description : Store the lower 15 bits of (A) in the designated ad- 
dress M. The upper 9 bits of M and all of (A) remain unchanged. 



SCHA 

Store 

Character Address 



18 17 16 15 14 



00 



46 


a 


b 


m 



a = addressing naode designator 
b = index register designator 
m = storage address; M = m + (B ) 

Instruction Description : Store the lower 17 bits of (A) in the address designated 
by M. The upper 7 bits of M and all of (A) remain unchanged. 
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Shift and Scale Instructions 



Operation 


Field 


Address Field 


Interpretation 


SSH 


10 


m 


Storage shift 


SHA 


12 


k,b 


Shift A 


SHQ 


12 


k.b 


Shift Q 


SHAQ 


13 


k,b 


Shift AQ 


SCAQ 


13 


k.b 


Scale AQ 



SSH 
Storage Shift 



18 17 15 14 



10 





m 



m = storage address 

Instruction Description: Sense bit 23 of the quantity stored at address m. If bit 
23 = "0" (positive), RNI from P + 1; if negative ("l'^'), RNI from P + 2. Shift (m) 
one place left, end around, and replace it in this same storage location. 

Comments : Address modification may not be used. 



SHA 
Shift A 



23 



18 17 16 15 14 



12 





b 


k 



b = index register designator 

k = unmodified shift count; K = k + (B") 

Instruction Description : (B^) and k, with their signs extended, are added. If 
b = 0, the sign of k is still extended. The sign and magnitude of the 24-bit suna 
determine the direction and magnitude of the shift. The computer senses only 
bits 00-05 and 23 of the sum for this information. For left shifts, the shift 
magnitude is the lower 6 bits of K ; for right shifts, the complement of the lower 
6 bits of K equals the shift magnitude. 

Examples: 

Shift left six positions: K = 00000006 

Shift right six positions: K = 77777771 

Comments : During left shifts, bits reaching the upper bit position of the A 
(during SHA) or Q (during SHQ) registers are carried end- around. Therefore, 
a left shift of 24 places results in no change in (A) or (Q). A left shift that ex- 
ceeds 24 places results in an effective shift of K-24 (or K-48) places. 

During right shifts, the sign bit is extended and the bits are shifted end-off. A 
right shift of 23 or more places results in (A) or (Q) becoming all "O's" or all 
"I's", depending upon the original sign. 



5-57 



Rev. A 



SHA/SHQ FLOW CHART 



SHA OR SHQ 
INSTRUCTION IN F 



EXTEND THE SIGNS OF k 
AND (B*") AND ADD 



YES 



/bit 23 OF SUM 

V equals"©" or " l" 



YES 



SHA 
INF? 



NO 



NO 



SHIFT lA) left 

END AROUND 

ACCORDING TO 

THE LOWER 6 BITS 

OF 'k' 



SHIFT (0) LEFT 

END AROUND 

ACCORDING TO 

THE LOWER 6 BITS 

OF 'k' 



SHA 
IN F? 



YES 



SHIFT (0) RIGHT, 

END OFF 

ACCORDING TO 

COMPLEMENT OF 

LOWER 6 BITS 

OF 'k' 



SHIFT (A) RIGHT 

END OFF 

ACCORDING TO 

COMPLEMENT OF 

LOWER 6 BITS 

OF 'K' 



RN I AT P + I 
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SHQ 
Shiff Q 



18 17 16 15 14 



12 


1 


b 


k 



b = index register designator 
k = shift count: K = k + (Bb) 

Instruction Description: Shift (Q). Refer to SHA description. 



SHAQ 
Shift AQ 



23 



18 17 16 IS 14 



13 





b 


k 



b = index register designator 

k = unmodified shift count; K = k+(Bt') 

Instruction Description : Shift (AQ). (B ) and k, with their signs extended, are 
added. If b = 0, the sign of k is still extended. The sign and magnitude of the 24- 
bit sum determine the direction and magnitude of the shift. The computer senses 
only bits 00-05 and 23 of the sum for this information. For left shifts, the shift 
magnitude is the lower 6 bits of K; for right shifts, the complement of the lower 
6 bits of K equals the shift magnitude. 



Examples: 

Shift left three places: 
Shift right three places: 



K = 00000003 

K = 77777774 



Comments : During left shifts, bits reaching the upper bit position of the A regis- 
ter are carried end-around to the lowest bit position of Q. Therefore, a left 
shift of 48 places results in no change in (AQ). A left shift exceeding 48 places 
results in an effective shift of K-48 places. During right shifts, the sign bit is 
extended and the bits are shifted end-off. A right shift of 47 or more places 
results in (AQ) becoming all "O's" or all "I's", depending upon the original sign. 



SCAQ 
Scale AQ 



23 



18 17 16 15 14 



00 



13 


1 


b 


k 



b = index register designator 

k = scale factor 

K = residue = k minus the number of shifts. 

If b = 1,2, or 3 , then K — B^" 

Instruction Description: (AQ) are shifted left, end -around, until the 2 highest 
order bits (46 and 47) are unequal. If (AQ) should initially equal positive or 
negative zero, 48^0 shifts are executed before the instruction terminates. During 
scaling, the computer counts the number of shifts. A quantity K, called the re- 
sidue, is equal to the scale factor 'k' minus the number of shifts made. If b = 0, 
this quantity is discarded; if b = 1,2, or 3, the residue is transferred to the 
designated index register. 
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Arithmetic Instructions 



Operation Field 



ADA, I 
RAD, I 
SBA, I 
ADAQ, I 
SBAQ, I 
MUA, I 
DVA, I 
MUAQ, I 
DVAQ, I 
FAD, I 
FSB, I 
FMU, I 
FDV, I 
ADM 
SBM 



30 
34 
31 
32 
33 
50 
51 
56 
57 
60 
61 
62 
63 
67 
67 



Address Field 



m, b 

m, b 

m, b 

m, b 

m, b 

m, b 

m, b 

m, b 

m, b 

m, b 

m, b 

m, b 

m, b 
r, Br, Si,s, Bs, S2 
r, Br, Si,s,Bs, S2 



Interpretation 



Add to A 

Replace add 

Subtract from A 

Add to AQ 

Subtract from AQ 

Multiply A 

Divide A 

Multiply AQ 

Divide AQ 

FP addition to AQ 

FP subtraction from AQ 

FP multiplication of AQ 

FP division of AQ 

Add fields 

Subtract fields 



ADA 
Add fo A 



IB 17 16 15 14 



00 



30 


a 


b 


m 



a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B°) 

Instruction Description : Add the 24-bit operand located at address M to (A). 
The sum replaces the original (A). 



RAD 
Replace Add 



18 17 16 15 14 



00 



34 


a 


b 


m 



a = addressing mode designator 
b = index register designator , 
m = storage address; M = m + (B ) 

Instruction Description : Replace the 24-bit operand at address M with the sum 
of (M) and (A). The original (A) remain unchanged. 
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SBA 
Subtract from A 



18 17 16 15 14 



00 



1 " 


a 


b 


m 



a = addressing mode designator 
b = index register designator 
m = storage address; M 



m + (B^) 



Instruction Description: Subtract the 24-bit operand located at address M from 
(A). The difference replaces the original (A). 



ADAQ 
Add to AQ 



18 17 16 15 14 



" 


a 


b 


m 



a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B^) 

Instruction Description: Add the 48-bit operand located in addresses M and 
M+1 to (AQ). The sum is displayed in AQ. 

Comments: The upper 24 bits of the 48-bit operand in memory are contained 
at address M. 



SBAQ 
Subtract from AQ 



23 



18 17 16 15 14 



33 





b 


m 



a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B ) 

Instruction Description: Subtract the 48-bit operand located in addresses M 
and M+1 from (AQ). The difference is displayed in AQ. 
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23 



16 17 16 15 14 



00 



Multiply A 



50 


a 


b 


m 



a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B") 

Instruction Description: Multiply (A) by the operand located at address M. 

NOTE 

The 48-bit product is displayed in QA. The higher order bits are in Q and 
the lower order bits are in A. 



DVA 
Divide A 



23 



18 17 16 15 14 



00 



51 


a 


b 


m 



a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B") 

Instruction Description: Divide the 48-bit operand in AQ by the operand at 
storage address M. TTie quotient is displayed in A and the remainder with sign 
extended is displayed in Q. If a divide fault occurs, the operation halts and 
program execution advances to the next address. The final (A) and (Q) are 
meaningless if a divide fault occurs. 



Rev. A 



5-62 



MUAQ 
Multiply AQ 



23 



18 17 16 15 14 



00 



1 » 


a 


b 


1 



a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B") 

Instruction Description : Multiply (AQ) by the 48-bit operand in addresses M 
and M+1. The 96-bit product is displayed in AQE, 

Comments: Refer to Figure 5-5 for operand formats. 



23 



18 17 16 15 14 



00 



Divide AQ 



\ " 


a 


b 


1 



a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (Bt>) 

Instruction Description: Divide (AQE) by the 48-bit operand in addresses M 
and M+1. The quotient is displayed in AQ, and the remainder with its sign ex- 
tended is displayed in E. 

Comments : If a divide fault occurs, program execution advances to the next 
The final contents of AQ and E are meaningless if a divide fault 



address 
occurs. 



Refer to Figure 5-5 for operand formats. 



NOTE 



Figure 5-5 illustrates operand format and bit allocations for all floating 
point instructions. Refer to the Floating Point section of Appendix B 
for additional floating point considerations and examples. 
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« 

lui 
0:1 



+ 



■^> 



p. 



I 



Figure 5-5. Operand Formats and Bit Allocations 
for MUAQ and DVAQ Instructions 
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FAD 
FP Addifion to AQ 



18 17 16 15 14 



00 



60 


a 


b 


1 



a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B ) 

Instruction Description: Add the 48-bit operand located in addresses M and 
M+1 to (AQ). The rounded and normalized sum is displayed in AQ. 

Comments : The higher order bits of E hold the portion of the operand that was 
shifted out of AQ during exponent equalization. 

Refer to Figure 5-6 for operand formats. 



FSB 
FP Subtracfion from AQ 



18 17 16 15 14 



00 



61 


a 


b 


m 



a = addressing mode designator 
b = index register designator 
m^ = storage address; M = m + (B") 

Instruction Description: Subtract the 48-bit floating point operand located at 
storage addresses M and M+1 from the floating point operand in AQ. The 
rounded and normalized difference is displayed in AQ. 

Comments : The upper order bits of E hold the portion of the operand that was 
shifted out of AQ during the equalization of exponents. Refer to Figure 5-6 for 
operand formats. 
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FMU 
FP Mult'iplicafion of AQ 



23 



18 17 16 15 14 



00 



62 


a 


b 


m 



a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B^) 

Instruction Description : Multiply the 48-bit floating point operand in AQ by the 
floating point operand located at storage addresses M and M+1. The rounded 
and normalized product is displayed in AQ. 

Comments : Bits 12-47 of E hold the lower 36 bits of the 72-bit unnormalized 
product. Refer to Figure 5-6 for operand formats. 



23 



18 17 16 IS 14 



FP Division of AQ 



63 


a 


b 


. 



a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B^) 

Instruction Description: Divide the floating point operand in AQ by the 48-bit 
floating point operand located at storage addresses M and M+1 . The rounded 
and normalized quotient is displayed in AQ. The remainder with sign extended 
appears in the E register. 

Comments: The sign of the remainder is the same as that of the dividend. 
Refer to Figure 5-6 for operand formats. 

NOTE 

The divisor must be properly normalized or a divide fault will result. 
Refer to Interrupt conditions. Section 4. 
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Figure 5-6. Operand Formats and Bit Allocations 
for Floating Point Arithmetic Instructions 
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ADM 
Add Field A to Field C 



P+ 1 



23 2120 1918 17 16 



Bs 



00 

3 



P + 2 



S2 



:j 



r = unmodified address of lowest order 
character in field A. R = r + [ Bp] 

Br = index register flag for field A 

If Br = 1 or 3, use index register B^ 
If Br = 2, use index register b2 
If Br = 0, no indexing 
s = unmodified address of lowest order 
character in field C. S = s + [Bs] 

Bg = index register flag for field C (same 
bit functions as Br) 

%l = 12-bit character count specifying the 
length of the A field 

$2 = 12 -bit character count specifying the 
length of the C field 

Instruction Description: Add the BCD contents of field A (addend) to field C 
(augend) proceeding from right to left. The upper 2 bits of the lowest order 
character in fields A and C contain the algebraic sign of their respective fields. 
The sign of the sum is in the upper 2 bits of the lowest order character of 
field C. This character is in the original address specified by S. 

Comments: Field A may be shorter than field C as carries can be set into pro- 
gressively higher order positions of field C. 

The BDP Condition register indicates a positive sign (00) or negative sign (10) 
according to the result in field C. A zero result may have either a positive or 
negative sign. K any character position of either field contains a lis - l^s '^°^^ 
(or the sign character contains a 123 - 178 code), it is converted to zero before 
the add operation, 
A BCD fault is generated if one of the following conditions occur: 

1. An arithmetic carry is attempted out of the upper limit of field C, 

2. Si >S2 

3. Zone portion (upper 2 bits) of characters in either field (except sign 
character) does not equal zero. 

4. Numeric portion (lower 4 bits) of characters in either field contains a 
BCD code greater than lln, except the sign character where a 12g code 
is legal. 

5. The lowest order character (sign character) in either field contains a 
72o code. 

Operation continues despite any BCD fault. 
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SBM 
Subtract Field 
A from Field C 



P + 1 



P + 2 



25 






8 


17 


16 










00 


67 





r 


23 


21 2019 18 17 IS 








00 


1 


Br 


Bs 


1 


23 




12 II 






00 


s, 


S2 



B., = 



s = 



Be = 



unmodified address of the lowest 

order character in field A. 

R = r + [ Br] 

index register flag for field A 

If Br = 1 or 3, use index register B-*- 

If Br = 2, use index register B^ 

If Br = 0, no indexing 

unmodified address of the lowest 

order character in field C, 

S = s + [Bs] 

index register flag for field C (same 

bit functions as Br) 

12-bit character count specifying the 

length of the A field 

12-bit character count specifying the 

length of the C field 



Instruction Description: Subtract the BCD contents of field A (subtrahend) from 
field C (minuend) proceeding from right to left. The upper two bits of the lowest 
order character in fields A and C contain the algebraic sign of their respective 
fields. The sign of the difference is in the upper two bits of the lowest order 
character of field C. This character is in the original address specified by S, 

Comments: S^ must be < S2 since field C must accommodate the result of the 
subtraction. 

The BDP Condition register indicates a positive sign (00) or a negative sign (10) 
according to the result in field C. A zero result may have either a positive or 
negative sign. If any character position of either field contains a lis - •'■'^8 code 



(or the sign character contains a 12g 
the subtract operation. 



173 code), it is converted to zero before 



The conditions for generating a BCD fault are identical to those for the ADM 
instruction (see page 5-68). 
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Logical Instructions 



Operation Field 


Address Field 


Interpretation 


XOI 


16 


y,b 


Exclusive OR of index and y 


XOA 


16 


y 


Exclusive OR of A and y 


XOA, S 


16 


y 


Exclusive OR of A and y, sign of y ex- 
tended 


XOQ 


16 


y 


Exclusive OR of Q and y 


XOQ, S 


16 


y 


Exclusive OR of Q and y, sign of y ex- 
tended 


ANI 


17 


y.b 


AND of index and y 


ANA 


17 


y 


AND of A and y 


ANA, S 


17 


y 


AND of A and y, sign of y extended 


ANQ 


17 


y 


AND of Q and y 


ANQ, S 


17 


y 


AND of Q and y, sign of y extended 


SSA, I 


35 


m, b 


Selectively set A 


SCA, I 


36 


m, b 


Selectively complement A 


LPA, I 


37 


m, b 


Logical product A 



NOTE 

The LDL(Load A, Logical) instruction may be found in the LOAD IN- 
STRUCTIONS subsection. 



The following two examples use logical instructions and illustrate the Exclusive 
OR and AND functions: 



EXAMPLE A : 

(A) = 23456701 
Execute: 16 4 50321 



(XOA, S) 



Final (A) 



(Binary Equivalents) 

010 Oil 100 101 110 111 000 001 
111 111 111 101 000 oil 010 001 

101 100 on 000 no loo oio ooo 

5 430 6420 



EXAMPLE B: 

(Q) = 23456701 
Execute: 17 7 77170 



(ANQ) 



Final (A) 



010 Oil 100 101 110 111 000 001 
000 000 000 111 111 001 111 000 

000 000 000 101 110 001 000 000 

0005 6 100 



Rev. A 



5-70 



xo; 

Exclusive OR of B and y 



23 18 1716 1514 



00 



16 





b 


y 



b = index register designator 

Instruction Description : Enter the selective complement (the Exclusive OR 
function) of y and (Bt)) back into the same index register. 

Comments: If b = 0, this is a no- operation instruction. 



XOA 
Exclusive OR of A cifid y 



23 18 17 15 14 



00 



{6 


6 


y 



Instruction Description: Enter the selective complement (the Exclusive OR 
function) of y and (A) back into the A register. 



XOA, S 
Exclusive OR of A and y 
Sign Extended 



23 1817 15 14 



00 



16 


4 


y 



Instruction Description: Same as XOA except the sign of y is extended. 



XOQ 
Exclusive OR of Q and y 



23 1817 15 14 



16 


7 


y 



Instruction Description: Enter the selective complement (the Exclusive OR 
function) of y and (Q) back into the Q register. 



XOQ, S 
Exclusive OR of Q and y 
Sign Extended 



23 18 17 15 14 



16 


5 


y 



Instruction Description: Same as XOQ except the sign of y is extended. 
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SSA 
Selectively Set A 



23 



18 17 16 15 14 



00 



1 " 


a 


b 


m 



a = addressing mode designator 
/] ,; b = index register designator 

m = storage address; M = m + (B°) 

Instruction Description: Selectively set the bits in the A register to "I's" for 
all corresponding ''I's" in the quantity at address M. Initial "I's" in A remain 
unchanged, 

EXAMPLE- (A) = 23456710 = 010 Oil 100 101 110 111 001 000 
(M) = 76345242 = 111 110 Oil 100 101 010 100 010 

Final (A) = 111 111 111 101 111 111 101 010 

77757752 



SCA 

Selectively 

Complement A 



18 17 16 15 14 



36 


a 


b 


m 



a = addressing mode designator 
b = index register designator 
m = storage address; M 



m + (B^) 



Instruction Description: Selectively complement the bits in the A register that 
correspond to the "1" bits in the quantity at address M. 

EXAMPLE: (A) = 23456710 = 010 Oil 100 101 110 111 001 000 
(M) = 20341573 = 010 00 Oil 100 001 101 111 Oil 

Final (A) 



000 Oil 111 001 111 010 110 Oil 
03717263 
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LPA 
Logical Product A 



23 



18 17 16 15 14 



00 



37 


a 


b 


m 






a = addressing mode designator 
b = index register designator 
m = storage address; M = m + (B") 



Instruction Description: Replace (A) with the logical product of (A) and (M). 

EXAMPLE: (A) = 23456710 = 010 Oil 100 101 110 111 001 000 
(M) = 45210376 = 100 101 010 001 000 Oil 111 110 



Final (A) = 000 001 000 001 000 Oil 001 000 
01010310 



ANI 
AND of B*'and y 



23 



18 1716 15 14 



17 





b 


y 



b = index register designator 

Instruction Description: Enter the logical product (the AND function) of y and 
(Bb) back into the same index register. 

Comments: If b = 0, this is a no- operation instruction. 



ANA 
AND of A and y 



23 



1817 15 14 



00 



7 6 y 



Instruction Description : Enter the logical product (the AND function) of y and 
(A) back into the A register. 



ANA,S 

AND of A and y. 

Sign Extended 



23 



18 17 15 14 



00 



17 


4 


» 



Instruction Description: Same as ANA except the sign of y is extended. 
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A Kin 
AND of Q and y 



18 17 15 14 



00 



■' 


7 


y 



Instruction Description : Enter the logical product (the AND function) of y and 
(Q) back into the Q register. 



ANQ, S 

AND of Q and y, 

Sign Extended 



23 18 17 15 14 



00 



17 


5 


1 



Instruction Description: Same as ANQ except the sign of y is extended. 
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Masked Searches and Compare Instructions 



Operation 


Field 


Address Field 


Interpretation 


MEQ 


06 


m, i 


Masked equality search 


MTH 


07 


m, 1 


Masked threshold search 


CPR, I 


52 


m, b 


Compare (within limits test) 


CMP 


67 


r, Br, Si, s,Bs,S2 


Compare fields 


CMP, DC 


67 


r, Br, s, Bg, §2 


Compare fields, with delimiting 



MEQ 

Masked 

Equality Search 



18 17 15 14 



06 


i 


m 



i = interval designator, to 7 
m = storage address 



Instruction Description : (A) is compared with the logical product of (Q) and (M). 
This instruction uses index register B-"- exclusively, m is modified just prior 
to step 3 in the test below. Instruction sequence follows: 

1. Decrement (B^) by i. (Refer to table below. ) 

2. If (b1) changed sign from positive to negative, RNI from P + 1; if not, 

3. Test to see if (A) = (Q) • (M). M = m + (B^). 
If (A) = (Q) • (M), RNI from P+2; if not, 

4. Repeat the sequence. 

Comments: i is represented by 3 bits, permitting a decrement interval selec- 
tion from 1 to 8. Address modification always utilizes (B^). Positive zero and 
negative zero are recognized as equal quantities. 



DESIGNATOR 


DECREMENT 


1 


INTERVAL 


1 
2 


1 
2 


3 


3 


4 


4 


5 


5 


6 


6 


7 


7 





8 



READ MEQ INSTRUCTION 
AT ADDRESS P 



DECREMENT 
(BI) BY "i" 



DID SIGN OF B' 

CHANGE POSITIVE 

TO NEGATIVE? 



, YES 



RNI FROM 
P+ I 



NO 



MODIFY : M = m + (b') 



NO 



.YES 



( A ) = ( Q) • ( M ) 



RNI FROM 
P+2 
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MTH 

Masked 

Threshold Search 



23 




18 


17 


15 14 




00 


07 


i 


m 



i = interval designator, to 7 
m = storage address 

Instruction Description: (A) is compared with the logical product of (Q) and 
JmY. This instruction uses index register B^ exclusively, m is modified just 
prior to step 3 in the test below. 

Instruction Sequence: 

1. Decrement (b2) by "i". (Refer to table below.) 

2. If (b2) changed sign from positive to negative, RNI from P + 1; if not, 

3. Test to see if (A)> (Q) • (M). M = m + (B^). 
H (A)> (Q) • (M), RNI from P + 2; if not, 

4. Repeat the sequence. 

Comments: i is represented by 3 bits, permitting a decrement interval selection 
from 1 to 8. Address modification always utilizes (B^). Positive zero and negative 
zero are recognized as equal quantities. 



DESIGNATOR 


DECREMENT 


i 


INTERVAL 


1 
2 


1 
2 


3 


3 


4 


4 


5 


5 


6 


6 


7 


7 





8 



READ MTH INSTRUCTION 
AT ADDRESS P 



NO 



DECREMENT 
(b2) by "i" 



DID SIGN OF b2 

CHANGE POSITIVE 

TO NEGATIVE ? 



YES 



RNI FROM 
P+ I 



NO 



MODIFY 



M = m + (b2) 



, YES 



( A ) > ( Q) • ( M) 



RNI FROM 
P + 2 
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CPR 

Compare 

(Wifbin Limits Test) 



23 



18 17 16 15 14 



52 


a 


b 


„ 



a = addressing mode designator 
b = index register designator 
m = storage address; M=ni+(Bb) 



Instruction Description: The quantity stored at address M is tested to see if it 
is within the upper limits specified by A and the lower limits specified by Q, 
The testing proceeds as follows: 



1. Subtract (M) from (A). If (M) > (A), RNI from address P + 1; 

2. Subtract (Q) from (M). If (Q) > (M), RNI from P + 2; if not, 

3. RNI from address P + 3, 



if not. 



Comments: The final state of the A and Q registers remains unchanged. 

(A) must be ^ (Q) initially or the test cannot be satisfied. 77777777 is not sensed 

as negative zero. The following table is a synopsis of the CPR test: 



Test 
Sequence 


Jump Address 
if Test is Satisfied 


(M) > (A) 
(Q) > (M) 
(A) > (M) ^ (Q) 


P+ 1 
P + 2 
P + 3 
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CPR INSTRUCTION 
IN F 



SUBTRACT (M) 
FROM (A) 



IS (M) >(A) ? 



NO 



SUBTRACT (Q) 
FROM (M) 



IS (Q) >(M) 7 



NO 



RNI FROM 
P + 3 



YES 



YES 



RNI FROM 
P + I 



RNX FROM 
P +2 



CPR FLOW CHART 
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CMP 

Compare Field A 

to Field C 





23 




18 1716 










00 


p 


67 





r 




23 2120 1918 1716 








00 


p + 1 


3 


Br 


Bs 


s 




23 


12 II 






00 


P + 2 


s, 


S2 



B, 



S. = 



unmodified address of the highest 

order character in field A 

R = r + (Bj,) 

index register flag for field A 

If Br = 1 or 3, use index register B^- 

If Br = 2, use index register b2 

If Br = 0, no indexing 

unmodified address of the highest 

order character in field C. 

S = s + (Bg) 

index register flag for field C (same 

bit function as Bj,) 

12 bit character count specifying the 

length of the A field 

12 bit character count specifying the 

length of the C field 



Instruction Description : Compare characters in field A with field C proceeding 
from left to right. Terminate the operation when an unequal character compari- 
son occurs and RNI at P + 3. If the comparison condition is not satisfied when 
one of the fields has been completely examined, the remainder of the other field 
is examined for blanks (60 codes). If the remaining characters are all blanks, 
the compare operation is terminated as an equal comparison and the next instruc- 
tion is read from P + 4. If the remainder of the larger field does not contain all 
blanks and: 



If Si > S2, 

If 4^ Si. 



then an A > C comparison condition exists, 
then an A < C comparison condition exists. 



Comments : The result of the comparison is entered into the BCD condition 
register as described in the table below. If the fields are unequal, the next 
instruction is read from P + 3. If the fields are equal, the next instruction is 
read from P + 4. The count of the characters processed is placed in B*^ regis- 
ter upon completion of the instruction. 



Comparison 
Condition 


Contents of BCR 


A = C 
A >C 
A <C 


OO2 
OI2 
IO2 
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CMP. DC 
Compare Field A to 
Field C, Delimited 



P + 1 



P + 2 



23 




18 17 16 










00 


67 


1 


r 


23 2120 1918 1716 








00 


3 


Br 


Bs 


s 


23 1817 


12 1 1 






00 


WM!^. 


DC 


,^2 



r = unmodified address of the highest 

order character in field A. 

R = r + (Br-) 
Br = index register flag for field A 

If Br = 1, or 3, use index register B 

If Br- = 2, use index register B^ 

If Bp = 0, no indexing 
s = unmodified address of the highest 

order character in field C. 

S = s + (Bg) 
Bg = index register flag for field C (same 

bit functions as B ) 
DC = 6 -bit delimiting character 
§2 - 12 -bit character count specifying the 

length of field C 



Field A always contains the same number of charac- 
ters as field C during a delimited compare operation. 
Bits 18 through 23 of P + 2 should be loaded with 
zeros. 



Instruction Description: Compare characters in field A with field C proceeding 
from left to right. Ternainate the operation when: 1) an unequal character com- 
parison occurs (the magnitudes of the unequal characters are noted - see table 
below), 2) all of the characters in the fields have been examined, 3) a character 
in either the A or C field equals the delimiting character. RNI at P + 3 for an 
unequal field comparison; RNI at P + 4 for an equal field comparison. 

3 
Comments: The count of the characters processed is placed in the B register 
upon completion of the instruction. The following table describes the state of the 
BDP Condition register when the operation is terminated; 



Terminating Comparison Condition 


Contents of BCR* 


A = C (through entire field or through 
delimiting character) 

A >C 

A <C 


OO2 

OI2 
IO2 
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Condition Test Instructions 



Operation Field 


Address Field 


Interpretation 


TMAV 77 
TST 67 
TSTN 67 


r, Br, S^ 

r, Br, Si 


Test memory availability 
Test field A for sign 
Test field A for numeric 



TMAV 

Test 

Memory Availability 



23 




18 


17 




12 


II 




00 


77 


61 


0000 



Instruction Description: This instruction is used to test core storage for the 
presence of a particular address. 

Comments: Prior to executing this instruction, the lower 15 bits of the testing 
address must be formed in B^. The upper 3 bits of the address will be zeros 
unless the OSR has been previously selected by the (ROS) 55. 4 instruction. 

If a storage reply is received within 5 microseconds after executing the instruc- 
tion, the address does exist, and the next instruction is read from P + 2. If a 
reply does not occur within 5 microseconds, the address does not exist in the 
system and the next instruction is read from P + 1. The contents of the test 
address are not returned to the CPU and are of no consequence during the test. 



TMAV INSTRUCTION 
IN F 



SEND TEST ADDRESS 
TO APPROPRIATE 
STORAGE MODULE 




STORAGE REPLY 

RECEIVED WITHIN 

5 MICROSECONDS ? 




5-81 



Rev. D 



TSTN 
Test Field A for Numeric P 



P + 1 



P + 2 



23 




18 


17 


16 








00 


67 


1 


r 


23 21 20 19 18 






00 


4 


Br 


^^^ 


^^^ 




^^^ 


23 


12 II 




00 


s, 


t 


mzm 


'WM^, 



r = unmodified address of the lowest 

order BCD character in field A 

R = r + (Bp 

B = index register flag for field A 

If B = 1 or 3, use index register B 

r 9 

If B =2, use index register B^ 

If B = 0, no indexing 

S . = numoer of BCD characters in field 



1 



A to be tested. 
Bits 00 - 18 of P + 1, and bits 00 - 11 of 
P + 2 should be loaded with zeros. 

Instruction Description : Examine the sign character of field A and record the 
results in the BDP Condition register (see Comments). Field A is scanned 
from right to left until S]^ is exhausted. If the BCD Fault is not set upon 
completion of the instruction, field A is numeric. The BCD Fault can be 
sensed by instruction. 

Comments: If field A contains all zeros and the sign character is recognized as 
zero (contains BCD code of 60, 52, 40, 32, 20, 12, or 00), the Condition 
register is set to "0". If field A does not equal zero, the Condition register is 
set as follows: 



Field A 


Contents of BDP 
Condition Register 


Positive - upper 2 bits of 

sign character are 
OOg, Olg, or llg 


'h 


Negative - upper 2 bits of 

sign character are 

1^2 


'^2 



A BCD fault is generated if one of the following conditions occur: 

1. Zone portion (upper 2 bits) of any character (except sign character) 
does not equal zero. 

2. Numeric portion (lower 4 bits) of any character contains a BCD code 
greater than lln, except the sign character where a 12„ code is legal. 

3. The lowest order character (sign character) contains a 72p code. 



Operation continues despite any BCD fault. 
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TST 
Test Field A for Sign 



P+ 1 
P + 2 



23 




8 


17 


16 






00 


67 







23 21 20 19 18 




00 


4 


Br 




^^^^^ 


^^^^ 


23 


12 II 


00 


Si 


^^^ 





'1 



unmodified address of the lowest 
order BCD character in field A 
R = r + (Br) 

index register flag for field A 
If Bjp = 1 or 3, use index register B^ 
If Bj^ = 2, use index register B^ 
If Bj, = 0, no indexing 
number of BCD characters in field A 
to be tested 



Bits 00 through 18 of P + 1, and bits 00 through 
11 of P + 2 should be loaded with zeros. 

Instructio n Description: Examine field A from right to left and determine if it 
is zero, greater than zero, or less than zero. The BDP Condition register is 
set to reflect the test results (see table below). The register is set to 00 if 
BCD codes of 52„, 40„, 32p, 20^, or 00 appear in the lowest order of field A 



^8 



8' 



when the remaining characters are zero. 

Comments- If field A contains all zeros and the sign character is recognized 
as zero (contains BCD code of 60, 52, 40, 32, 20, 12 or 00), the Condition 
register is set to "00". If field A does not equal zero, the Condition register 
is set as follows: 



Field A 



Positive - upper 2 bits of 

sign character are 
00^, 01„, or llo 



Negative - upper 2 bits of 

sign character are 
10„ 



Contents of BDP 
Condition Register 



01. 



10, 



A BCD fault is generated if one of the following conditions occur: 

1. Zone portion (upper 2 bits) of any character (except sign character) does 



3. 



not equal zero. 

Numeric portion (lower 4 bits) of any character contains a BCD code 
greater than llg, except the sign character where a 12g, code is legal. 
The lowest order character (sign character) contains a v2o code. 



Operation continues despite any BCD fault. 
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Sensing Instructions 



Operation Field 


Address Field 


Interpretation 


EXS 77 
COPY 77 
INTS 77 
INS 77 
CINS 77 


X, ch;x^O 
X, eh;x=0 
X, ch 
X, ch;x^O 
X, ch;x=0 


Sense external status 
Copy external status 
Sense interrupt 
Sense internal status 
Copy internal status 



GENERAL NOTES 

Refer to the ACI instruction for special considerations regarding the 'ch' desig- 
nator in these instructions. Refer to the SSIM instruction in the Interrupt group 
for a method of program testing for the presence of I/O channels in a system. 



EXS 

Sense 
External Status 



18 17 15 14 12 II 



00 



77 


2 


Ch 


X 



ch = I/O channel designator, 0-7 

x = external status sensing mask code 
(see Comments below) 

Instruction Description: When a peripheral equipment controller is connected 
to an I/O channel by the CON (77.0) instruction, the EXS instruction can sense 
conditions within that controller. Twelve status lines run between each con- 
troller and its I/O channel. Each line may monitor one condition within the 
controller, and each controller has a unique set of line definitions. To sense a 
specific condition, a "1" is placed in the bit position of the status sensing mask 
that corresponds to the line number. When this instruction is recognized, RNI 
at address P + 1 if an external status line is active when its corresponding mask 
bit is "1". If no selected line is active, RNI at address P + 2. 

Comments : Refer to the 3000 Series Computer Systems Peripheral Equipment 
Codes manual (Pub. No. 60113400) for a complete list of status response codes. 



copy 

Copy 
External Status 



18 17 15 14 12 II 



77 


2 


Ch 






ch = I/O channel designator, 0-7 

Instruction Description: This instruction performs the following functions: 

1. The external status code from l/O channel ch is loaded into the lower 
12 bits of A. (See EXS instruction. ) 

2. The contents of the Interrupt Mask register are loaded into the upper 
12 bits of A. (See Table 5-3. ) 

3. RNI from address P + 1. 
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TABLE 


5-3. INTERRUPT MASK REGISTER BIT ASSIGNMENTS 


Masked Bit 






Positions 


Mask Codes (x) 


Interrupt Conditions Represented 


00 


0001 


I/O Channel (includes interrupt gener- 


01 


0002 


1 ated within the channel 


02 


0004 


2 and external equipment 


03 


0010 


3 interrupts) 


04 


0020 


4 


05 


0040 


5 


06 


0100 


6 


07 


0200 


7 


08 


0400 


Real-time clock 


09 


1000 


Exponent overflow /underflow & BCD faults 


10 


2000 


Arithmetic overflow & divide faults 


11 


4000 


Search/Move completion 



INTS 
Sense Infernjpf 



23 



18 17 IS 14 12 II 



77 


4 


ch 


X 



ch = I/O channel designator, 0-7 
X = interrupt sensing mask code 

Instruction Descri ption: Sense for the interrupt conditions listed in Table 5-4, 
RNI from P + 1 if an interrupt line is active and the corresponding sensing mask 
bit is a "1". If none of the selected lines are active, RNI from P + 2, Bits 
08-11 represent conditions that may be sensed without regard to channel desig- 
nation. 

TABLE 5-4. BIT ASSIGNMENTS FOR INTERRUPT SENSING CONDITIONS 



Mask Bit 






Positions 


Mask Codes (x) 


Interrupt Conditions Represented 


00 


0001 


External equipment interrupt line active 


01 


0002 


1 


02 


0004 


2 


03 


0010 


3 


04 


0020 


4 


05 


0040 


5 


06 


0100 


6 


07 


0200 


7 


08 


0400 


*Real-time clock 


09 


1000 


*Exponent overflow /underflow & BCD faults 


10 


2000 


*Arithmetic overflow & divide faults 


11 


4000 


*Search/Move completion 



Internal faults are cleared as soon as they are sensed. 
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INS 
Sense Internal Status 



18 17 15 14 12 M 



77 


3 


ch 


X 



ch = I/O channel designator, 0-7 
X = internal status sensing mask code 

Instruction Description : Table 5-5 lists the bit definitions of the internal status 
sensing mask. Bits 00-04 and 06-07 represent conditions within I/O channel 
Bits 05 and 08-11, which represent internal faults, may be sensed without re- 
gard to channel designation. 

To sense a specific condition, load a "1" into the bit position of the mask that 
corresponds to the condition. When this instruction is executed, RNI from 
address P + 1 if an internal status line is active and the corresponding mask 
bit is a "1". If none of the selected lines is active. RNI from address P + 2. 

TABLE 5-5. INTERNAL STATUS SENSING MASK 



Mask Bit 






Positions 


Mask Codes (x) 


Condition Represented 


00 


0001 


Parity error on channel ch 


01 


0002 


Channel ch busy reading 


02 


0004 


Channel ch busy writing 


03 


0010 


External reject active on channel ch 


04 


0020 


No- response reject active on channel ch 


05 


0040 


^Illegal write 


06 


0100 


Channel ch preset by CON or SEL, but no 
reading or writing in progress 


07 


0200 


Internal I/O channel interrupt on channel 
ch upon: 

1) completion of read or write opera- 
tion, or 

2) end of record 


08 


0400 


^Exponent overflow /underflow fault (floating 
point) 


09 


1000 


^Arithmetic overflow fault (adder) 


10 


2000 


^Divide fault 


11 


4000 


*BCD fault 



'internal faults are cleared as soon as the condition is sensed. 
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CINS 
Copy Internal Status 



18 17 15 14 12 II 



" 


3 


ch 


0000 



ch = I/O channel designator, 0-7 

Instruction Description: This instruction performs the following functions: 

1. The internal status code is loaded into the lower 12 bits of A, (See 
INS instruction. ) 

2. The contents of the Interrupt Mask register are loaded into the upper 
12 bits of A. (See Table 5-3, ) 

3. RNI from address P + 1. 
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Pause Instructions 



Operation Field 


Address Field 


Interpretation 


PAUS 77 
PRP 77 


X 
X 


Pause on condition 
Priority pause 



Pause 



23 



12 II 



77 


60 


X 



X = pause sensing mask code 

Instruction Description: This instruction allows the program to halt for a max- 
imum of 40 ms if a condition (excluding typewriter - see note) defined by the 
pause sensing mask exists. (See Table 5-6, ) If a "1" appears on a line that 
corresponds to a mask bit that is set, the count in P will not advance. If the 
advancement of P is delayed for more than 40 ms, the next instruction is read 
from address P + 1. K none of the lines being sensed are active, or if they be- 
come inactive during the pause, the program immediately skips to address 
P + 2. If an interrupt occurs and is enabled during a PAUS, the pause condition 
is terminated, the interrupt sequence is initiated and the address of the PAUS 
instruction is stored as the interrupted address. 

NOTE 

If either bit 08, 09 or 10 (or any combination of these bits) is set and 
the sensed condition exists, a pause will not occur and the instruc- 
tion at P + 1 is read up immediately. If these bit(s) are set but the 
condition(s) does not exist, the program imnaediately skips to P + 2. 
For all other bits, the normal PAUS routine is followed, TYPE 
FINISH and/or TYPE REPEAT are cleared if bit 9 and/or 10 are set 
and the sensed condition(s) does not exist. 





TABLE 


5-6. PAUSE SENSING MASK 


Mask Bits 


Mask Codes 


Condition 


Notes 


00 


0001 


I/O channel busy 


Channel read or write op- 


01 


0002 


1 


eration in progress, the 


02 


0004 


2 


External MC logic within 


03 


0010 


3 


the channel is set, or a 


04 


0020 


4 


Reply or Reject from a 


05 


0040 


5 


previous operation is still 


06 


0100 


6 


present at the channel 


07 


0200 


7 




08 


0400 


Typewriter busy 


Typewriter input or output 
in progress 


09 


1000 


Typewriter NOT 
finish 


Finish logic not set 


10 


2000 


Typewriter NOT 
repeat 


Repeat logic not set 


11 


4000 


Search/Move con- 


Search or Move operation 






trol busy 


in progress 
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PAUS INSTRUCTION IN F 



ARE ANY OF BITS 8,9, OR 
10 OF THE PAUSE SENSING 
MASK SET TO "l" ? 



NO 



IS A "l" ON ANY LINE, OTHER 

THAN 8, 9, OR 10 CORRESPONDING 

TO THE PAUSE SENSING MASK ? 



YES 



DO NOT ADVANCE P, 
AND DO NOT RNI 



NO 



HAVE 40 MS ELAPSED 7 



YES 



RNI @ P + l 



YES 



NO 



RNI @ P + l IMMEDIATELY 



YES 



IS A "l" ON A BUSY LINE 
-X CORRESPONDING TO"l"OF ANY 

BIT IN THE PAUSE SENSING MASK?/ 



NO 



RNI @ P+2 IMMEDIATELY 



YES 



HAVE ALL "l" BUSY LINES 
CHANGED TO "o" ? 



NO 



NO f HAS AN INTERRUPT OCCURED 
( AND WAS IT ENABLED 7 



YES 



P IS STORED AT ADDRESS 

00004 AND INTERRUPT 

ROUTINE INITIATED 



PRP 
Piiority Pause 



23 




13 


17 




12 


II 




00 


" 


61 


X 



X = pause sensing mask code 

Instruction Description : This instruction performs the same operation as the 
preceding PAUS (77. 6) instruction, however, the real-time clock is prevented 
from incrementing during the pause. 

Comments : Preventing the real-time clock from incrementing enables block 
control to continue an I/O operation without being referenced by the clock. 
This provides a more efficient I/O transfer operation. 
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Interrupt Instructions 



Operation 


Field 


Address Field 


Interpretation 


EINT 


77 




Enable interrupt control 


DINT 


77 




Disable interrupt control 


INCL 


77 


X 


Clear interrupt 


SSIM 


77 


X 


Selectively set interrupt mask 


SCIM 


77 


X 


Selectively clear interrupt mask 


GILO 


77 


cm 


Channel interrupt lockout 


SFPF 


77 




Set floating point fault 


SBCD 


77 




Set BCD fault 



23 




18 


17 




12 


II 


00 


1 " 


74 


^^^ 


^^^^ 



EINT 

Enable 

Interrupt Control 

Instruction Description: This instruction enables the interrupt control system. 
One additional instruction at P + 1 is executed before the processor is interrupted, 
provided that the additional instruction requires no more than one Read Address 
(RADR) cycle. If the EINT instruction is executed at P, the earliest possible 
interrupt will occur at P + 2. For an instruction containing more than one RADR 
cycle, the earliest possible interrupt can occur during its second RADR cycle. 

Comments ; Bits 00 through 11 shoiild be loaded with zeros. 



DINT 

Oisofa/e 

Intenupt Control 



23 


18 


17 




12 


II 


00 


" 


73 


W^!M>. 


WM^. 



Instruction Description: This instruction disables the interrupt control system. 
The system remains disabled until an EINT instruction is executed. Selected 
interrupts may still be sensed. 

Comments: Bits 00 through 11 should be loaded with zeros. 



INCl 
Clear Interrupt 



23 



12 II 



" 


50 


X 



X = interrupt mask register codes 

Instruction Description : This instruction clears the interrupt faults defined by 
the mask codes in Table 5-7. Internal I/O channel interrupts are cleared by this 
instruction and although the Interrupt Clear is sent to peripheral equipment, not 
all equipments drop their interrupt lines. Refer to the Peripheral Equipment 
Reference Manual, Pub. No. 60108800, for information of specific equipment. 
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TABLE 5-7. INTERRUPT MASK REGISTER BIT ASSIGNMENTS 



Mask Bit 
Positions 


Mask Codes (x) 


Interrupt Conditions Represented 


00 


0001 


I/O Channel (includes interrupts gener- 


01 


0002 


1 ated within the channel 


02 


0004 


2 and external equipment 


03 


0010 


3 interrupts) 


04 


0020 


4 


05 


0040 


5 


06 


0100 


6 


07 


0200 


7 


08 


0400 


Real-time clock 


09 


1000 


Exponent overflow /underflow & BCD faults 


10 


2000 


Arithmetic overflow & divide faults 


11 


4000 


Search/Move completion 



SSIM 
Selectively 
Set Interrupt Mask Register 



77 


52 


X 



X = interrupt mask register codes 



Instruction Description: This instruction selectively sets the Interrupt^ Mask 
register according to the interrupt mask code x.* For each bit set to^^ 1^ in x, 
the corresponding bit position in the Interrupt Mask register is set to 1 (see 
Table 5-7). Bit positions representing non-existent I/O channels cannot be set 



Comments : A program test for the existence of I/O channels for a system is 
as follows: 

1. Set the interrupt mask bits to all "l"s by executing a SSIM 
(77 5 27777) instruction. 

2. Execute either a COPY or CINS instruction and examine the 
upper 12 bits of A. 

3. As bits representing non-existent I/O channels cannot be set, a 
"O" in bits 00-07 of the Interrupt Mask register indicates a non- 
existent I/O channel. 

SCIM 

Selectively Clear 

Interrupt Mask Register 



23 




18 


17 




12 


II 




00 


77 


53 


X 



X = interrupt mask register codes 

Instruction Description: This instruction selectively clears the Interrupt Mask 
register according to the interrupt mask code x.* For each bit set to "l" in x, 
the corresponding bit position in the Interrupt Mask register is set to "O" (see 
Table 5-7). 



*The Interrupt Mask register must not be set or cleared while the interrupt system 
is enabled to prevent extraneous interrupts from occuring. 
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C/IO 
Channel Interrupt Lockout 



12 I I 10090807 



00 



wm 



cm 



cm = channel mask 



Bits 08 and 11 should be loaded with zeros. 

Instruction Description: Disables all external interrupts on channel(s) cm while 
the channel(s) are busy. Termination of the I/O operation clears the disabling 
function. 

Comments : Bit 00 corresponds to channel 0, bit 01 corresponds to channel 1, etc. 
More than one channel may be set to "1" for multiple channel interrupt lockout. 
The mask is cleared by termination of the I/O operation, by clearing the channel(s), 
and by a Negate Channel Interrupt Lockout signal from certain peripherals. 



SFPF 
Sot Floating 
Point Fault 



23 




18 


17 




12 


■ II 


00 


77 


71 


WM^y 


WM!^. 



Instruction Description: The floating point fault logic sets when a floating point 
fault occurs. This instruction is used when the optional floating point arithme- 
tic logic is not present in a system. An interpretive software routine should 
recognize any conditions which would have caused a fault if the operation had 
been executed by the optional hardware. 

Comments: Bits 00 through 11 should be loaded with zeros. 



S%CD 
Set BCD Fault 



18 17 



00 



m 



Instruction Description: The BCD fault logic sets when a BCD fault occurs. 
This instruction is used when the optional BCD arithmetic is not present in a 
system. An interpretive software routine should recognize any condition which 
would have caused a fault if the operation had been executed by the optional 
hardware. 

Comments: Bits 00 through 11 should be loaded with zeros. 
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Input/Output Instructions 



Operation Field 


Address Field 


Interpretation 


CLCA 


77 


cm 


Clear I/O channel(s) 


lOCL 


77 


X 


Clear I/O channel(s) and equipment 


CON 


77 


X, ch 


Connect to external equipment 


SEL 


77 


X, ch 


Select function 


CTI 


77 




Set console typewriter input 


CTO 


77 




Set console typewriter output 


INPC, INT, 


73 






B,H,G 




ch, r, s 


Character- Addressed Input to storage 


IN AC, INT 


73 


ch 


Character- Addressed Input to A 


INPW, INT, 


74 






B,N,G 




ch, m, n 


Word- Addressed Input to storage 


INAW, INT 


74 


ch 


Word-Addressed Input to A 


OUTC, INT, 


75 






B,H 




ch, r, s 


Character-Addressed Output from 
storage 


OTAC, INT 


75 


ch 


Character- Addressed Output from A 


OUTW, INT, 


76 






B,N 




ch, m, n 


Word-Addressed Output from storage 


OTAW, INT 


76 


ch 


Word- Addressed Output from A 



Unlike I/O operations with A, I/O instructions with storage are buffered. As soon 
as Read or Write signals are activated. Main Control relinquishes control of the 
storage I/O operation and returns to the main program. 

Registers 00 through 178 of the Register File are reserved for I/O operations. 
Registers GO through 07 are used for storing the modified instruction words con- 
taining the current character addresses. (Refer to Table 5-8). Registers lOs 
through 17 hold the modified sub -instruction words containing the last character 
addresses (+ 1 depending upon the instruction parameters). In cases where 
addresses require modification to obtain dynamic I/O operations, care should be 
exercised to provide proper readout and restoration of the modified control bits. 

During the execution of word addressed storage I/O instructions, the addresses 
'm' and 'n' are shifted left two bit positions. From this time on and when they 
are stored in the Register File, they are recognized as character addresses. 

Before executing an I/O instruction in Executive mode, the desired program state 
number (0 through 7) must be loaded into the lower three bits of the A register. 
The program state number is automatically transferred to the upper digit of Reg- 
ister File location OX for referencing during buffered I/O tasks, thus enabling the 
A register to be used for other operations. 

Table 5-8 and its accompanying example illustrate the relationship between the 
Register File addresses, their contents, and the individual instructions. Each 
I/O instruction should be referenced for a description of its particular parameters 
and a flowchart of the overall operation. The ACI instruction, described else- 
where in this section, should be consulted for special I/O channel considerations. 
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When performing I/O operations with peripheral equipment not equipped with a 
12 to 6-bit disassembly feature, character oriented instructions should not be 
used J thus preventing erroneous transmission parity errors. 



TABLE 5-8. MODIFIED I/O INSTRUCTION WORDS 





Instruction 


Relative location 

of instruction words 

(See individual instructions) 


Register 

File 

location 


Contents of Register 
File location 


Operations 
With Storage 


73 (INPC) 

74 (INPW) 

75 (OUTC) 

76 (OUTW) 


P 

P + 1 

P 

P + 1 

P 

P + 1 

P 
P + 1 


IX 
OX 

IX 
OX 

IX 

ox 

IX 

ox 


3 



1 

2 


TO 

a 

a< 

ni Xi 

o 


73 (INAC) 

74 (INAW) 

75 (OTAC) 

76 (OTAW) 


P 

P + 1 

P 

P + 1 

P 

P + 1 

P 

P + 1 


IX 

ox 

IX 

ox 

IX 

ox 

IX 

ox 


7 

4 

5 

6 



X = An I/O channel designator "ch", 0, 1, 2, 3, 4, 5, 6, or 7. 
* = The program number (lowest 3 bits of the 'A' Register) 



Upper digit position 
(Blanks indicate 
digits unaltered by 
control logic) 



EXAMPLE: 

Execute the following INPW instruction. 

P = 74 003200 (A) = 00000001 

P+ 1 = 20 003100 QQr.e T/r>> r-K i 

P+ 2 = 01 003300 3306 I/O Channel 

ANALYSIS: I/O Channel 2 is specified; thus Register File location 12 is 
used to store 04015000 and location 02 holds 10014400. 

This instruction specifies 12- to 24 -bit assembly, no interrupt 
upon completion, forward storage, and an unconditional jump 
to address 03300 as a reject instruction. 
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The first word address (m) of the block of storage assigned to 
receive data from an external equipment is m = 03100. 

The last word address (n) of the assigned storage area (plus 
one) is n = 03200. 

The first 12 -bit byte is stored in bits 12 through 23 at address 
003100, the second byte in bits 00 through 11, etc. 



CLCA 
Clear Channel Activity 



12 I I 10090807 



00 



77 


51 




2 




cm 



cm = channel mask 

Bits 08 and 11 should be loaded with zeros. 

Instruction Description : Clear only the selected I/O channel(s). 

Comments : The peripheral equipment associated with the selected channel(s) 
are not cleared by executing this instruction. Bit 00 corresponds to channel 0, 
bit 01 corresponds to channel 1, etc. More than one channel may be set to "1" 
for multiple channel clearing. 



lOCL 

Clear I/O, Typewriter, 

and Search/Move 



23 



00 



1 " 


51 


X 



X = block control clearing mask 

Instruction Description: This instruction may be used to clear the I/O channels. 
It also clears all associated peripheral equipment, the typewriter or the Search/ 
Move control according to bits set in the Block Control clearing mask, (See 
Table 5-9.) 
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TABLE 5-9. 


BLOCK CONTROL CLEARING MASK 


Mask Bits 


Mask Codes (x) 


Controls Cleared 


00 


0001 


I/O channel 


01 


0002 


1 


02 


0004 


2 


03 


0010 


3 


04 


0020 


4 


05 


0040 


5 


06 


0100 


6 


07 


0200 


7 


08 


0400 


Typewriter 


09 


1000 


(see note) 


10 


2000 


(see note) 


11 


4000 


Search/Move 



NOTE 

If bits 09 and 10 are both set or both clear, the channel(s) specified by- 
bits 00 through 07 of the mask are cleared, i.e.. Read or Write, Status, 
and Channel Interrupt are cleared. A 5. 5 usee Clear signal is also 
sent to the peripheral equipment and controllers connected to the selected 
channel(s). 

If bit 09 is clear and bit 10 is set, the instruction will clear the 
channel(s) only and the 5.5 usee Clear signal is not transmitted. Bit 
08 clears the typewriter as well as the Type Load or Type Dump logic 
in Block Control. 



CON 
Connect 



18 17 15 14 12 II 



00 



77 





ch 


X 



ch = I/O channel designator, 0-7 
X = 12 bit connect code. Bits 09-11 

select one of eight controllers which 
may be attached to channel ch. Bits 
00-08 select the peripheral units 
connected to the controller. 

Instruction Description: This instruction sends a 12-bit connect code along with 
a connect enable to an external equipment controller on I/O channel ch. If a 
Reply is received from the controller within 100 usee, the next instruction is 
read from address P + 2. If a Reject is received or there is no response within 
100 usee, a reject instruction is read from address P + 1. If the I/O channel is 
busy, a reject instruction is read from address P + 1. 
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(0 



to 
I 

05 



R+ar1^\ 


(FCN Reg. ) 




Request 
Program Priority 

In Block Control 


-HI— 
/ 


Send Connect 
Signal To All 


^o / Channel X 


\ 


Gate Connect 
Code from F 
Reg. to O Reg. 




Transmit Cpnnect 
Code To Equipments 
On Channel X 






Channels 


-^ Busy? 1 - 








Await Program Priority 




Yes 

1 




I ' 














RNI At 

P+1 

(Reject) 




Release 
Block Control 















-o 



I 

CO 



O 
o 
3 
3 
(D 
O 

o 

•a 

O 

3 




Equipment Numbe 
Switch = E, 
Unit Switch 



lYes J Parity Error 



Equipment 
Connected 



Equipment 
Reserved By 
Another Channel 



Equipm ent 
Sends Reply 
(Connect Complete! 



RNI At 
P+2 



Equipment 
Sends Reject 



Equipment 
Disconnects 



T^f- 



No Response 
Channel Generates 
Internal Reject 



RNI. At 

H p+1 

(Reject) 



100 Usee Delay 



cp. 23 18 17 15 14 12 II 



77 


1 


ch 


« 



Select Function 



ch = I/O channel designator, 0-7 
X = 12-bit function code. Each piece of 
external equipment has a unique set 
of function codes to specify opera- 
tions within that device. Refer to 
the 3000 Series Computer Systems 
Peripheral Equipment Codes Publi- 
cation No. 60113400 for a complete 
list of function codes. 

Instruction Description: This instruction sends a 12-bit function code along 
with a function enable to the unit connected to I/O channel ch. If a Reply is re- 
ceived from the unit within 100 usee, the next instruction is read from P + 2. 
If a Reject is received or there is no response within 100 usee, or if the I/O 
channel is busy, a reject instruction is read from address P + 1. 

The following conditions or combination of conditions result in a Reject: 

1) No Unit or Equipment Connected: The referenced device is not connected 
to the system and cannot recognize a Select Function instruction. If no 
response is received within 100 usee, the Reject signal is generated 
automatically by the I/O channel, 

2) Undefined Code: When the Function code x is not defined for the specific 
device, a Reject may be generated by the device. However, in some 
cases an undefined code will cause the device to generate a Reply although 
no operation is performed. (Refer to the reference manual pertaining to 
the specific peripheral device. ) 

3) Equipment or Unit Busy or Not Ready: The device cannot perform the 
operation specified by the function code x without damaging the equipment 
or losing data. For example, a Write End of File code is rejected by a 
tape unit if the tape unit is rewinding. 

4) Channel Busy: The selected data channel is currently performing a Read 
or Write operation or a Reply or Reject from a previous operation is still 
present at the channel. 



Rev. B 5-96. 



fD 
<! 



<S 
(\> 

Ol 

1 

as 




Await Program Priority 



Send Function 
Signal To All 
Channels 


/ 


Channel X 


w 


Gate Function 
Code From F 
To O 




Release 
Block Control 


,/ 


\ 


Busy? 




*v 








Yes 






1 
















RNI At 
P+1 
(Reject) 





•o 





-J 




-J 


Ol 


cn 


1 


(D 


CO 


1— ' 


05 


fD 



o 

3 
O 
o 
p 

r+ 
O 

13 



o- 



Transmit Function 
Code To Equipments 
On Channel X 



Equipment 
Connected? 



100 Usee Delay 



Parity Error"; 




Set I/O 
Parity Error 
In Channel 



^ 



i 



Channel Generates 
Internal Reject 



RNI At 

P+1 
(Reject) 



Reply ? 



RNI At 
P+2 



Reject 



dd 



CTI 

Sef Console 

Typewriter Inpuf 



18 17 



12 II 
— P55 



00 



Bits 00 through 11 should be loaded with zeros. 

Instruction Description: This instruction, like the TYPE LOAD switch, permits 
a block of data to be entered into storage as soon as the TYPE LOAD indicator 
lights. If a block of data smaller than the one defined by registers 23 and 33 is 
to be typed, the FINISH switch should be depressed when the typing is completed. 
If more data is entered than the defined block can hold, the excess data is lost. 
If a typing error occurs, the REPEAT button should be depressed. When either 
the FINISH or REPEAT switch is depressed> the typewriter input operation 
is terminated and the appropriate status Dits (09 and 10) may be sensed with the 
PAUS instruction. (For additional information refer to the PA US instruction. ) 



CTO 

Set Console 

Typewriter Output 



23 




18 


17 




12 


II 


00 


77 


76 


W^A 


'mm 



Bits 00 through 11 should be loaded with zeros. 

Instruction Description: This instruction, like the TYPE DUMP switch, causes 
the typewriter to print out the block of data defined by the character addresses 
in registers 23 and 33. 

NOTE 

The CTI and CTO instructions are mutually exclusive. Typewriter busy 
should be checked before these instructions are used and before registers 
23 and 33 are altered. 
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INPC 

Character-Addressed 

Input to Storage 



P+ 1 



23 






18 17 


16 




00 


73 





S 


23 21 20 19 18 17 16 




00 


ch 


G 


B 


H 


1 
N 

T 




r 





B = "1" for backward storage 
ch = I/O channel designator, 0-7 

H = "0" for 6- to 24-bit assembly 

H = "1" for 12- to 24-bit assembly 
INT = "1" for interrupt upon completion 

r = first character address of I/O data 
block; becomes current address as 
I/O operation progresses 

s = last character address of input data 
block, plus one (minus one, for back- 
ward storage) 

G = "1" for word count control 

Instruction Description: This instruction transfers a character address block 
of data, consisting of 6-bit characters or 12-bit bytes, from an external equip- 
ment to storage. During 6- to 24-bit assembly (H = 0), the lower 6 bits of suc- 
cessive data words (12-bit data words from the 3306, 24-bit data words from the 
3307) are loaded into successive characters in storage, the first character being 
loaded into character address r. The next character is loaded into character 
address (r + 1) if doing forward storage (B = 0), into (r - 1) if doing backward 
storage (B = 1). During 12- to 24-bit assembly (H = 1), successive 12-bit bytes 
are loaded into successive halves of storage words. The first byte will be loaded 
into the upper or lower half of the storage word, depending upon character address 
r. If B = 0, the next byte is loaded into (r + 2); if B = 1, the next byte is loaded 
into (r - 2). During 12- to 24-bit assembly, the lowest bit of each character add- 
ress is forced to remain a "0" in register OX. This ensures that assembled bytes 
are in either the upper or the lower half of the word being stored. 

If channel 'ch' is not busy, the bxiffered I/O operation with storage commences 
while Main Control performs an RNI at P 4- 3. Main Control continues executing 
the main program while the I/O operation occurs simultaneously. If channel 'ch' 
is initially busy. Main Control performs an RNI at P +2 and the I/O operation 
does not occur. 



NOTES 

When bit 20 of the subinstruction word at P + 1 is "1", the word 
count control feature allows this I/O operation to continue beyond 
an End-of-Record signal. In practice, when an End-of-Record 
signal is sent, the Read line drops but the buffer operation does 
not terminate. The Read signal sent to the external equipment then 
reappears until the word count is satisfied. This signal appears as 
a new input instruction to the external equipment, but as a continue 
Read to the I/O channel. 



If H = "1", an even character count must be used, 
odd, the last character will be lost. 



If the count is 
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B = "1" for backward storage 
ch = I/O channel designator, 0-7 
INT = "1" for interrupt upon completion 
N = "0" for 12- to 24-bit assembly 
N = "1" for no assembly 
m = first word address of I/O data block; 

becomes current address as I/O 

operation progresses 
n = last word address of input data block, 

plus one (minus one, for backward 

storage) 
G = "1" for word count control 
Bits 15 and 16 at P and P + 1 should be 
loaded with zeros. 

Instruction Description: This instruction transfers a word- addressed data block 
from an external equipment to storage. Transferring 12-bit bytes or 24-bit 
words depends upon the type of I/O channel used. The 3306 utilizes 12-bit bytes 
and the 3307 uses 24-bit words. 

During forward storage and 12- to 24-bit assembly, the first byte of a block of 
data is stored in the upper half of the memory location specified by the storage 
address. Conversely, during backward storage, the first byte is stored in the 
lower half of the memory location. 

If channel 'ch' is not busy, the buffered I/O operation with storage commences 
while Main Control performs an RNI at P + 3. Main Control continues executing the 
main program while the I/O operation occurs simultaneously. If channel 'ch' is 
initially busy. Main Control performs an RM at P + 2 and the I/O operation does 
not occur. 

NOTES 

When bit 20 of the subinstruction word at P + 1 is "1", the word count 
control feature allows this I/O operation to continue beyond an End-of- 
Record signal. In practice, when an End- of- Record signal is sent, the 
Read line drops but the buffer operation does not terminate. The Read 
signal sent to the external equipment then reappears until the word 
count is satisfied. This signal appears as a new input instruction to the 
external equipment, but as a continue Read to the I/O channel. 

If N = 1 and a 3306 is used, the upper 12 bits of each storage word will 
be unchanged. If N = 1 and a 3307 is used with a 12-bit device, the upper 
12 bits will be zeros. 
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B = "1" for backward storage 
ch = I/O channel designator, 0-7 

H = "0" for 24- to 6-bit disassembly 

H = "1" for 24- to 12-bit disassembly 
INT = "1" for interrupt upon completion 

r = first character address of I/O data 
block; becomes current address as 
I/O operation progresses 

s = last character address of output data 
block, plus one (minus one, for back- 
ward output) 

Bit 20 at P + 1 should be loaded with a "O" 



Instruction Description: This instruction transfers a character-addressed block 
of data, consisting of 6 -bit characters or 12-bit bytes, from storage to an exter- 
nal equipment. During 24- to 6-bit disassembly (H = 0), the first character is 
transferred from character address r. The next character is transferred from 
(r + 1) if forward storage (B = 0), from (r - 1) if backward storage (B = 1). Dur- 
ing 24- to 12-bit disassembly (H = 1), the first byte will be transferred from the 
upper or lower half of the storage word, depending upon character address r. If 
B = 0, the next byte is transferred from (r + 2); if B = 1, the next byte is trans- 
ferred from (r - 2). 

If channel 'ch' is not busy, the buffered I/O operation with storage commences 
while Main Control performs an RNI at P + 3. Main Control continues executing 
the main program while the I/O operation occurs sim.ultaneously. If channel 'ch' 
is initially busy. Main Control performs an RNI at P + 2 and the I/O operation 
does not occur. 



NOTE 

If H = "1", an even character count must be used, 
the last character will be lost. 



If the count is odd. 
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B = "1" for backward storage 
ch = I/O channel designator, 0-7 
INT = "1" for interrupt upon completion 
m = first word address of I/O data block; 
becomes current address as I/O 
operation progresses 
"0" for 24- to 12-bit disassembly 
"1" for straight 12- or 24-bit data 
transfer 
n = last word address of output data block, 
plus one (minus one, for backward 
output) 
Bits 15 and 16 at P and bits 15,16, and 20 of 
P + 1 should be loaded with zeros. 
Instruction Description: This instruction transfers a word-addressed block of 
data consisting of 12-bit bytes or 24-bit words frona storage to an external 
equipment. 

With no disassembly, 12 or 24-bit transfer capability depends upon whether a 
3306 or 3307 I/O channel is used. If an attempt is made to send a 24-bit word 
over a 3 306 I/O channel, the upper byte will be lost. 

If channel 'ch' is not busy, the buffered I/O operation with storage commences 
while Main Control performs an RNI at P + 3. Main Control continues executing 
the main program while the I/O operation occurs simultaneously. If channel 'ch' 
is initially busy. Main Control performs an RNI at P + 2 and the I/O operation 
does not occur. 
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*See text for differences between 3306 and 3307. 
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ch = I/O channel designator, 0-7 
INT = "1" for interrupt upon completion 

Bits 00 through 16 at P and P + 1 should be loaded 
with zeros. 

Instruction Description : This instruction transfers a 6-bit character from an 
external equipment into the lower 6 bits of the A register. (A) are cleared prior 
to loading, and the upper 18 bits remain cleared. When the I/O operation with A 
is completed, RNI at P + 3. If channel 'ch' is busy and the operation cannot be 
performed, RNI at P + 2. 
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Figure 5-11. 73 I/O Operation with A 
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ch = I/O channel designator, 0-7 
INT = "1" for interrupt upon completion 

Bits 00 through 16 at P and P + 1 should be loaded 
with zeros. 

Instruction Description : This instruction transfers a 12-bit byte into the lower 
12 bits of A or a 24-bit word into all of A from an external equipment. Trans- 
ferring 12 or 24 bits depends upon whether a 3306 or 3307 I/O channel is used. 
(A) is cleared prior to loading and, in the case of a 12 -bit input, the upper 12 
bits remain cleared. When the I/O operation with A is completed, RNI at P + 3. 
If channel 'ch' is busy and the operation cannot be performed, RNI at P + 2. 

NOTE 

Bits 18, 19, and 20 may be all "O's" when a 3306 Data 
Channel is used. However, when bit 18 = "1", bit 19 = "0" 
or "1", and bit 20 = "0", this instruction can be used with 
either a 3306 or 3307 (when the 12- to 24-bit assembly feature 
is not utilized). This eliminates the need to alter a program 
when a 3307 is selected in place of a 3306 or vice versa. 

If the assembly feature of the 3307 is utilized, bits 18, 19, 
and 20 take on the following significance; 

• For 12- to 24-bit forward assembly, bits 18, 19, and 20 = 

• For 12- to 24-bit backward assembly, bits 18, 19, and 20 = 2 
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Figure 5-12. 74 I/O Operation with A 
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ch = I/O channel designator, 0-7 
INT = "1" for interrupt upon completion 



Bits 00 through 16 at P and P 
with zeros. 



1 should be loaded 



Instruction Description: This instruction transfers a character from the lower 
6 bits of A to an external equipment. The original (A) are retained. When the 
I/O operation with A is completed, RNI at P + 3. If channel 'ch' is busy and the 
operation cannot be performed, RNI at P + 2. 
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Figure 5-13. 75 I/O Operation with A 
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ch = I/O channel designator, 0-7 
INT = "1" for interrupt upon completion 

Bits 00 through 16 at P and P + 1 should be loaded 
with zeros. 

Instruction Description : This instruction transfers the lower 12 bits of A or 
(A) to an external equipment, depending upon the type of I/O channel (3306 or 
3307) that is used. The original (A) remain unchanged. When the I/O operation 
with A is completed, RNI at P + 3. If channel 'ch' is busy and the operation 
cannot be performed, RNI at P + 2. 



NOTE 

Bits 18, 19, and 20 may be all "O's" when a 3306 Data 
Channel is used. However, when bit 18 = "1", bit 19 = "0" 
or "1", and bit 20 = "0", this instruction can be used with 
either a 3306 or 3307 (when the 24- to 12-bit disassembly 
feature is not utilized). This eliminates the need to alter 
a program when a 3307 is selected in place of a 3306, or 
vice versa. 



If the disassembly feature of the 3307 is utilized, bits 18, 
19, and 2 take on the following significance: 



• For 24- 

• For 24- 



to 12-bit forward disassembly, bits 18, 19, and 20 = 2 
to 12-bit backward disassembly, bits 18, 19, and 20 = 



Rev. A 



5-110 




(P) - F 
(FCN HEG) 



Request 
Block 
Control 



(P+ 1) 
Read 



Channel 
Busy? 



Wait P'or Block Control 
Then S Bus Priority 



(P + 1 ) - Z" 

(P) -zi 



RNI IS? 
P + 2 
(Reject) 



■G 



G> 



Activate Read/ 
Write on I/O 
Channel 0-7 



Store Z (P+ 1) 
In One Register 
(00-07) 



Store Z (P) 

In One Register 

(10 - 17) 



Release Block 
Control And 
Scanner 



I/O Channel 

Generates 

Block Control 

Request 



<D 



Await 
Priority 



Q>^ 



Read Up 

Registers 
OX I IX 



Await 
Reply 



Output One 
Word From 



I/O Channel 
Generates 
Data Signal 




Reply From 
Controller 



Terminate 
Output 



Interrupt 



Exit RNI 

at P + ;j 



X z I/O Channel CH (0-7) 



Figure 5-14. 76 I/O Operation with A 
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Bits 00 through 14 should be loaded with zeros. 

Instruction Description : Clear bit 02 of the Condition register, enabling (ISR) to 
be used as the upper 3 bits of address for all storage references during Program 
State. 

Comments: A Master Clear produces the same effect as this instruction. 
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Bits 00 through 14 should be loaded with zeros. 

Instruction Description: Set bit 02 of the Condition register, enabling (OSR) to 
be used as the upper 3 bits of address for all operand references in Executive 
mode. 

Comments: Refer to Interrupts During Executive Mode in Section 4 for 
additional information. 



SBJP 

Set 
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Instruction Description : Set a boundary jump condition flag (bit 00 of the condi- 
tion register). 

Comment : After this instruction is executed, the next jump instruction senses 
the flag and causes the instruction to reference the ISR for relocation. When the 
jump instruction is executed, the boundary jump condition flag is cleared and the 
Program State is set. 

Refer to 'Interrupts During Executive Mode' in Section 4 for additional infor- 
mation. 
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Bits 00 through 11 should be loaded with zeros. 

Instruction Description : The processor (computer) executing this instruction 
sends an interrupt to an associated processor via a special cable. The inter- 
rupt remains active in the receiving computer until it is recognized. 
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Instruction Description: Set the destructive load condition flag (bit 01 of the CR). 



Comments : After this instruction is executed, the next Load A (LDA) instruc- 
tion senses the flag and causes the following operations to occur: 

1, Load (M) from LDA instruction into A and restore 77777777 into 
(M). 

2, Clear the destructive load condition flag when executing the LDA 
instruction. 

Refer to 'Interrupts During Executive Mode' in Section 4 for additional infor- 
mation. 

This instruction is useful in controlling multiple CPU's during multi- processing 
instructions. 
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r = unmodified address of the highest order 
BCD character in field A. R = r + [ B^] 

Bjp = index register flag for field A. . 

If Bp = 1 or 3, use index register B 
If Bj, = 2, use index register B^ 
If B = 0, no indexing 
unmodified address of the highest order 
bits in binary field C. M = m + [ Bml 
index register flag for binary field C. 
(same bit functions as B ). Bits 02-14 
of the index register are used for word 
address indexing (13 bit index-sign 
extended). Bits 00 and 01 must be set 
to "I's". 
S, = number of BCD characters to be con- 
verted. 

Bits 00 and 01 of P + 1, and bits 00 through 11 of 
P + 2 should be loaded with zeros. 

Instruction Description: Convert a BCD number of up to 14io numeric characters 
in magnitude (including sign) into its binary equivalent in one's complement no- 
tation and store the result in locations M and M + 1. 

Comments: The resultant binary number is placed into the words at locations M 
and M + 1. The sign of the binary number is always stored in bit 23 of M and the 
sign of the original BCD number is located in the upper 2 bits of the lowest order 
character in field A. The maximum positive BCD number (fourteen 9's) is equal 
to 26571420364377778. The complement of this number in M and M + 1 equals a 
negative field of fourteen 9's. 



The B register contains 



The BDP Condition register is set to the sign of field A, 
a count of the BCD characters converted. 

A BCD fault is generated if one of the following conditions occur: 

1. Zone portion (upper 2 bits) of any character (except sign character) does 
not equal zero. 

2. Numeric portion (lower 4 bits) of any character in field A contains a BCD 
code greater than llo, except the sign character where a 12g code is legal. 

3. The lowest order character (sign character) contains a 72g code. 

4. More than 14, q BCD characters are specified by S ]^. 

Operation continues despite any BCD fault. 
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2. 

0, no indexing 



Bits 02-14 of the index register are used for word address 
indexing (13 bit index- sign extended) . Bits 00 and 01 
must be set to "I's". 

n = unmodified address of the highest or- 
der BCD character in field C. 
N= n+ [Bn] 
Bn = index register flag for field C. 
(same bit functions as Bj-q) 

Bits 00 and 01 of P, bits 00 and 01 of P + 1, and bits 00 
through 23 of P + 2 should be loaded with zeros. 

Instruction Description: Convert the 48-bit binary number (including sign) at M 
and M + 1 into its signed, numeric BCD equivalent and store in field C. 

Comments: (M) and (M + 1) are always analyzed for the binary number to be con- 
verted. This is true even if the binary number does not utilize all of the bit posi- 
tions of M. The sign of the binary number is stored in the upper two bits of the 
lowest order BCD character in field C and is set in the BDP Condition register. 
The sign of the original binary number is located in bit 23 of M. (Refer to Appen- 
dix B and F for additional BCD information. ) 

A BCD fault is generated if the conversion results in a number of more than 14, q 
BCD characters. However the lower 14, q characters will be correct. 

Highest Order BCD 
Zeros are always stored here /Character Position 
/ — ^ • — ■ 

(N) = ■ 
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13 



(N+l) = 
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BCD character positions 
appear in this order. 
(This character position - 
always contains the sign 
of the field. ) 



(N+2)= 
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(N+3)= 
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unmodified address of the highest or- 
der character in BCD field A. 
R = r + [B^] 

index register flag for field A. 
If Bj, = 1 or 3, use index register B-"- 
If Bj. = 2, use index register B^ 
If Bj, = 0, no indexing 
unmodified word address of the highest 
order characters in ASCII field C. 
M = m + [ Bm] 

index register flag for field C 
(same bit functions as B ) . Bits 
02-14 of the index register are 
used for word address indexing (13 
bit index- sign extended). Bits 00 
and 01 must be set to "1' s". 
number of characters to be converted 



Bits 00 and 01 at P + 1 and bits 12 
P + 2 should be loaded with zeros. 



23 of 



Instruction Description : Convert a field of up to 4095 6-bit BCD characters in 
field A into the 8 -bit American Standard Code for Information Interchange 
(ASCII) infield C. 

Comments: Conversion proceeds from left to right (Refer to Appendix A for a 
comparative listing of BCD and ASCII codes. ) 

If the last ASCII character stored occupies bits 12-19, zeros are stored in bits 
00-07, The BCD codes of 123, 323, and 523 are not treated as zero for this 
instruction. The count in the B^ register upon completion equals four times the 
niimber of store cycles. The BDP Condition register is set to the sign of field A. 

The first ASCII character is always placed in this character position of the word 
specified by M. \ 
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unmodified address of the highest or- 
der character in BCD field A. 
R = r + [Bj,]. 

index register flag for field A 
If Bj, = 1 or 3, use index register B^ 
If Bj, = 2, use index register B^ 
If Bj, = 0, no indexing 
unmodified address of the highest or- 
der word in ASCII field C, 
M = m + [ Bin] 

index register flag for field C 
(same bit functions as Bp, Bits 
02-14 of the index register are used 
for word address indexing (13-bit 
index- sign extended). Bits 00 and 
01 must be set to ones, 
number of characters in ASCII field C 
6-bit delimiting character compared 
against characters in field A. 



Bits 18 through 23 at P + 2 and 00 and 01 at P + 1 
should be loaded with zeros. 

Instruction Description: Convert a field of up to 4095 6-bit BCD characters in 
field A into the 8-bit American Standard Code for Information Interchange (ASCII) 
in field C. The conversion proceeds from left to right. The operation is termin- 
ated when the number of characters specified byS2has been converted or the 
delimiting character is recognized in field A, A character equal to the delimiting 
character is converted when encountered. 



Comments: The BCD codes of 12g, 32o, and 52g are not treated as zero for this 

'Bter upon completion equals four times the 



instruction. The count in the B^ regis! 
number of store cycles. 



The first ASCII character is always placed in this character position of the wore 
specified by M. \ 
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So = 



unmodified word address of the highest 
order characters in ASCII field A. 

M=m + B (Refer to diagram below.) 
m '^ 

index register flag for field A ^ 

If B = 1 or 3, use index register B 

if B''^ = 2, use index register B^ 

m 
If B = 0, no indexing 

Bits i)2-14 of the index register are 

used for word address indexing (13-bit 

index- sign extended). . Bits 00 and 01 

must be set to ones. 

unmodified address of the highest order 

character in BCD field C. S = [s + Bs] 

index register flag for field C 

(same bit functions as Bj^^) 

number of characters in BCD field C 



Bits 00 and 01 of P and bits 12- 
loaded with zeros. 



23 of P + 2 should be 



Instruction Description: Convert a field of up to 4095 8 -bit American Standard 
Code for Information Interchange (ASCII) characters in field A into 6 -bit BCD 
characters in field C. The conversion proceeds from left to right. The operation 
is terminated when §2 is exhausted. 

Comments: A BCD fault is generated if bit positions 05 and 06 for any character 
contain both "I's" or both "O's" (an illegal character). An illegal,^ character is set 



to zero in field C and conversion continues to completion, 
cates the number of BCD characters stored. 



The B"^ register indi- 



The first ASCII character is always located in this character position of the word 
specified by M. Shaded areas are not used. 
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unmodified word address of the highest 
order characters in ASCII field A. 
(Refer to diagram below, ) 
M = m + Bj^ 

index register flag for field A -^ 

If B = 1 or 3, use index register B 
If B™' = 2, use index register B"^ 
If B = 0, no indexing 
Bits"62-14 of the index register are 
used for word address indexing (13-bit 
index- sign extended). Bits 00 and 01 
must be set to "I's". 

unmodified address of the highest order 
character in BCD field C. S = [s + BsJ 
index register flag for field C. 
(same bit functions as B^^) 
%2~ number of characters in BCD field C 
DC = 8 -bit delimiting character compared 
against characters in field A 



B 



Bits 20 through 23 at P + 2 and 00 and 01 at P 
should be loaded with zeros. 



Instruction Description: Convert a field of up to 4095 8-bit American Standard 
Code for Information Interchange (ASCII) characters in field A into 6-bit BCD 
characters infield A. Conversion proceeds from left to right. The operation 
is terminated when %2 is exhausted or an ASCII character equal to the delimiting 
character is recognized. A character equal to the delimiting character is con- 
verted when encountered. 

Comments: A BCD fault is generated if bit positions 05 and 06 for any character 
"I's" or both "O's" (an illegal character). An illegal character is 



contain both — _- - - — - „ 

set to zero in field C and conversion continues to completion, 
indicates the number of BCD characters stored 



The B"^ register 



The first ASCII character is always derived from this character position of the 
word specified by M. Shaded areas are not used. 



M 



M+ 1 



20 19 



221 



FIRST ASCII 
CHARACTER 



12 II 



OS 07 



m 



SECOND ASC 
CHARACTER 



u 



20 19 



08 07 



00 
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^^ CHARACTER 
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unmodified address of the lowest or- 
der character in the A field. 
R = r + [ B^] 

index register flag for field A ^ 

If Bj. = 1 or 3, use index register B 
If Bp = 2, use index register B 
If Bp = 0, no indexing 
unmodified address of the lowest or- 
der word in field C. 
M 



m + [ B^] 



B 



m 



index register flag for field C 
(same bit functions as B ) 
Bits 02-14 of the index register are 
used for word address indexing (13-bit 
index- sign extended). Bits 00 and 01 
must be set to "I's". 

So = number of 6 -bit characters in field A 
to pack. 

Bits 00 and 01 or P -h 1, and bits 12 through 23 of 
P -1- 2 should be loaded with zeros. 

Instruction Description: Convert from right to left, a field of numeric 6-bit BCD 
characters in field A into 4-bit BCD characters and store the result in field C. 
The upper 2 bits of all 6 -bit characters are renaoved. 

Comments: The sign of field A is contained in the upper 2 bits of the lowest order 
character. This sign is converted into a 4-bit sign character (lOlO™ - positive, 
lOllp - negative) and is placed in the low order character position of field C prior 
to packing BCD characters. Any A field character with a 12o - 17o code is forced 
to a zero in field C. A full word store is used. Any unfillecr4-bit characters in 
the highest order word are stored as zeros. The B^ register contains a count 
equal to four times the number of store cycles. The BDP Condition register is 
not used, 

A BCD fault is generated if one of the following conditions occur: 

1, Zone portion (upper 2 bits) of any character (except sign character) does 
not equal zero. 

2, Numeric portion (lower 4 bits) of any character in field A contains a BCD 
code greater than llg, except the sign character where a 12g code is legal, 

3, The lowest order character (sign character) is field A contams a 72g code. 

Operation continues despite any BCD fault. 
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If B™^ = 2 
If B? = 0, 



unmodified address of the lowest or- 
der word in field A. 
M = m + [ Br] 
B_„ = index register flag for field A -. 

If B_ = 1 or 3, use index register B 
use index register B^ 

, no indexing 

Bits"b2-14 of the index register are used 
for word address indexing (13-bit index- 
sign extended). 

Bits 00 and 01 must be set to "I's". 
s = unmodified address of the lowest order 
character in field C. S = []s + Bs^] 
B = index register flag for field C 

^ (same bit functions as B ) 
Sp = number of characters resulting in 
field C. 

Bits 00 and 01 of P and bits 12 through 23 should be 
loaded with zeros. 

Instruction Description: Convert a field of numeric 4-bit BCD characters in field 
A into 6-bit BCD characters and store the result in field C. The upper 2 bits of 
the new 6-bit characters are all set to "00" except the lowest order character 
which receives the algebraic sign from the 4-bit sign character (lowest order) in 
field A. Field C contains one less character than field A due to the elimination 
of the 4-bit sign character. 



"10" 



Comments: The conversion proceeds from right to left commencing with the sign 
character of the 4-bit BCD field. If the sign is positive (lOlOg), a "GO" is stored 
in the upper 2 bits of lowest order 6-bit BCD character; if negative (101 Ig), a 
is stored in the upper 2 bits of this character. Any A field character (other than 
the sign character) containing a 12o - n q code results in a zero in field C. 

o 

The B register indicates the number of 6-bit characters stored. The BDP Con- 
dition register is not used. 

A BCD fault is generated if one of the following conditions occur: 

1. The sign character in field A is other than lOlOg or lOllg (the sign of 
field C is then set to zero), or 

2. Any other character in field A contains a 12o - ITq code, except the 
second lowest character where a 12o code is legal. 

Operation continues despite any BCD fault. 
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Character Search Instructions 




Operation Field 




Address Field 


Interpretation 


SRCE,INT 


71 


SC, r, s 


Search for character equality 


SRCN,INT 


71 


SC, r. s 


Search for character inequality 


SCAN, LR, EQ 


65 


r, Bj,,S2, SC 


Scan field (left to right) for equal 
condition 


SCAN, LR, EQ, DC 


65 


r, Br, h. SC 


Scan field (left to right) for equal 
condition with delimiting 


SCAN, LR, NE 


65 


T,B^, S2,SC 


Scan field (left to right) for not 
equal condition 


SCAN,LR, NE, DC 


65 


r,Bj., S2.SC 


Scan field (left to right) for not 
equal condition with delimiting 


SCAN, RL, EQ 


65 


r,Br, S2,SC 


Scan field (right to left) for equal 
condition 


SCAN,RL, EQ, DC 


65 


r,Br, S2,SC 


Scan field (right to left) for equal 
condition with delimiting 


SCAN, RL, NE, DC 


65 


r, Br, S2, SC 


Scan field (right to left) for not 
equal condition 


SCAN,RL, NE, DC 


65 


r, Br, ^2, SC 


Scan field (right to left) for not 
equal condition with delimiting 
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SRCE 

Search for 

Character Equality 
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INT = "1" for interrupt upon completion 
s = last character address of the 
search block, plus one 
SC = 6 -bit BCD scan character 

r = first (current) character address 
of the search block 

Instruction Description: This instruction initiates a search through a block of 
character addresses in storage looking for equality with the scan character, SC. 
If Search/ Move control is not busy, the buffered search operation commences 
while Main Control performs an RNI at P + 3. Main Control continues executing 
the main program while the search operation occurs simultaneously. If Search/ 
Move control is initially busy. Main Control performs an RNI at P + 2 and the 
search operation does not occur. 

As a search progresses, r is incremented until the search terminates when 
either a comparison occurs between the scan character 'SC and a character in the 
storage field, or until r=s. If a comparison does occur, the address of the satisfy- 
ing character may be determined by inspecting r. To do this, transfer the con- 
tents of register 20 to A with instruction TMA (53 20020). 

Register 20 of the register file is reserved for the second instruction word 
which contains the current character address of the search block. Register 30 
is reserved for the first instruction word which contains the last character ad- 
dress of the search block, plus one. 

Figure 5-15 is a flow chart of steps that occur during a search operation. 
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Search for 
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INT = "1" for interrupt upon completion 
s = last character address of the 
search block, plus one 
SC = 6-bit BCD scan character 
r = first (current) character address 
of the search block 

Instruction Description : This instruction initiates a search through a block of 
character addresses in storage looking for inequality with scan character SC. 
If Search/ Move control is not busy, the buffered search operation occurs 
simultaneously. If Search/ Move control is initially busy. Main Control performs 
an RNI at P + 2 and the search operation does not occur. 

As a search progresses, r is incremented until the search terminates when 
either an unequal character comparison occurs between the search character SC 
and a character in storage, or until r = s. If an unequal character comparison 
does occur, the address of the satisfying character may be determined by in- 
specting r. To do this, transfer the contents of register 20 to A with instruc- 
tion TMA (53 20020). 

Register 20 of the register file is reserved for the second instruction word 
which contains the current character address of the search block. Register 30 
is reserved for the first instruction word which contains the last character ad- 
dress, plus one of the search block. 

Figure 5-16 is a flow chart of steps that occur during a search operation. 
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r = unmodified address of the highest or- 
der character in field A, R = r + [ B]-] 

Bj^ = index register flag for field A 

If Bj. = 1 or 3, use index register B-'- 
If Bj, = 2, use index register B^ 
If B-j. = 0, no indexing 

SC = 6-bit scan character compared against 
characters in field A 

§2 = number of characters to be searched 

Bits 00 through 18 of P + 1 and bits 12 through 17 
of P+ 2 should be loaded with zeros. 

Instruction Description: Search field A from left to right beginning with the 
6 -bit character at location R and RNI at P + 4 if a character is found that is 
equal to the scan character, SC. If a character is not found that equals the SC 
after the entire field defined by 83 has been searched, RNI at P + 3. 

Comments : If a character comparison occurs during the search, the number of 
searched characters is transferred to the lower 12 bits of b3. If an unsuccessful 
search is made, then (fiS) = §2- The upper 3 bits of b3 are of no consequence 
in this instruction. BCD codes of 12o, 32p, and 52o do not compare equal to 
zero for this instruction. 00 

The BDP Condition register is not used. 
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r = unmodified address of the highest or- 
der character in field A. R = r + [ B^] 



Br = index register flag for field A 

If Bj, = 1 or 3, use index register B-*- 
If B = 2, use index register b2 
If Bp = 0, no indexing 

SC = 6-bit scan character compared against 
characters in field A, 

^2 = number of characters to be searched. 

DC = 6-bit delimiting character compared 
against characters in field A 

Bits 00 through 18 of P + 1 should be loaded with 
zeros. 

Instruction Description: Search field A from left to right beginning with the 
6- bit character at location R and RNI at P + 4 if a character is found that is 
equal to the scan character, SC. If a character is not found that equals the SC 
after the entire field defined by §2 has been searched or if a character is found 
that equals the delimiting character, DC, RNI at P+3. (If SC equals DC and com- 
parison with field A occurs, RNI at P + 4), 

Comments: If a character comparison is found during the search, the number 
of characters searched is transferred to the lower 12 bits of B|. If an unsuc- 
cessful search is made, then (B^) = S2 • The upper 3-bits of B-^ are of no 
consequence in this instruction, BCD codes of 12, 
equal to zero for this instruction. 

The BDP Condition register is not used. 



32o, and 52o do not compare 



Rev. B 



5-130 



SCAN, LR, NE 

Search Field A Leff 

fo Right for Inequality 



P + 1 



P + 2 



23 




18 17 16 








00 


1 - 





r 


23 21 20 19 18 






00 


[E 


Br 


^^^ 


W^^^^/. 


^^^ 


^^ 


23 18 17 


12 II 




00 


" 


^M 


WW 

mi 


s. 1 



unmodified address of the highest or- 
der character in field A. R = r + [ Bj-] 



Bj. = index register flag for field A 

If B^ = 1 or 3, use index register B-*- 
use index register B^ 
no indexing 
SC = scan character which is compared 
against characters in field A. 
number of characters to be searched 



If B = 2, 
If bJ. = 0, 



Bits 00 through 18 of P + 1 and bits 12 through 17 
of p+ 2 should be loaded with zeros. 



Instruction Description: Search field A from left to right beginning with the 6- 
bit character at location R, and RNI at P + 4 if a character is found that is not 
equal to the scan character , SC. If a character is not found that is not equal 
to the SC after the entire field defined by Sg has been searched, RNI at P + 3. 



Comments: If an unequal character comparison is found during the search, the 
number of characters searched is transferred to the lower 12 bits of B . If all 
characters searched are equal to the SC, then (B^) =§2. The upper 3 bits of B^ 
are of no consequence in this instruction. BCD codes of 12g, 32g, and 52g do not 
compare equal to zero for this instruction. 



The BDP Condition register is not used. 
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SCAN, LR, NE, DC 
Search Field A Left to 
Right for Inequality, Delimited 



P + 1 



P + 2 



23 




18 17 


16 
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SC 
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B, 



SC 

^2 
DC 



unmodified address of the highest or- 
der character in field A. R = r + [ Bj,] 

index register flag for field A 

If Br = 1 or 3, use index register B^ 



2, use index register B^ 
0. no indexing 



If Bi 

If Bj. , 

scan character which is compared 

against characters in field A. 

number of characters to be searched 

6-bit delimiting character compared 

against the characters in field A 



Bits 00 through 18 of P + 1 should be loaded with 
zeros. 



Instruction Description: Search field A from left to right beginning with the 
6- bit character at location R, and RNI at P + 4 if a character is found that is 
not equal to the scan characterise. If a character is not found that is not 
equal to the SC after the entire field defined by S2 has been searched or if a 
character is found that equals the delimiting character, DC, RNI at P + 3. 
(If SC equals DC and an unequal comparison with field A occurs, RNI at P + 4). 

Comments: If an unequal character comparison is found during the search, the 
number of characters searched is transferred to the lower 12 bits of B"^. If all^ 



characters searched are equal to the SC, 
are of no consequence in this instruction, 
an unequal comparison to zero. 

The BDP Condition register is not used. 



then (B"^) = S2. 
BCD codes of 



The upper 3 bits of B*^ 



12 



8' 



32o and 52o cause 



8 



8 
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SCAN, RL, EQ 

Search Field A Righf 

to Left for Equalify 



P + 1 



P + 2 
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18 17 16 



23 21 20 19 18 



I Br 
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r = unmodified address of the lowest or- 
der character in field A. R = r + [ B^,] 

Bj, = index register flag for field A 

If Bj^ = 1 or 3, use index register B-*- 
If Bj- = 2, use index register b2 
If B]^ = 0, no indexing 

SC = scan character which is compared 
against characters to be searched. 

S2 = number of characters to be searched 

Bits 00 through 18 of p + 1 and bits 12 through 17 
of P + 2 should be loaded with zeros. 

Instruction Description: Search field A from right to left beginning with the 6-bit 
character at location R and RNI at P + 4 if a character is found that is identical to 
the scan character, SC. If a character is not found that equals the SC after the 
entire field defined by So has been searched, RNI at P + 3. 

Comments: H a character comparison is found during the search, the number of 
characters searched is transferred to the lower 12 bits of B . If an imsuccessful 
search is made, then (B^) = So. The upper 3 bits of B^ are of no consequence in 
this instruction. BCD codes of 12o, 32o, and 52o do not compare equal to zero. 

The BDP Condition register is set ot the sign of field A (upper 2 bits of lowest 
order character). 
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SCAN, RL, EQ, DC 

Search Field A Right 

to Left for Equality, Delimited 



P 
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r = unmodified address of the lowest or- 
der character in field A. R = r + [ Bj,] 

Bj, = index register flag for field A 

If Br = 1 or 3, use index register B^ 
If Br = 2, use index register b2 
If Br = 0, no indexing 

SC = scan character which is compared 
against characters in field A. 

'2 = number of characters to be searched 
DC = 6-bit delimiting character compared 
against the characters in field A 

Bits 00 through 18 of P + 1 should be loaded with 
zeros. 

Instruction Description: Search field A from right to left beginning with the 6- 
bit character at locations R and RNI at P + 4 if a character is found that is 
equal to the scan character , SC. If a character is not found that equals the SC 
after the entire field defined by ^2 ^^^ been searched or if a character is found 
that equals the delimiting character , DC, RNI at P + 3 (if SC equals DC and an 
equal comparison with field A occurs, RNI at P + 4). 

Comments: H a character comparison is found during the search, the number of 

characters searched is transferred to the lower 12 bits of B^. If an unsuccessful 

search is made, then (B^) =89. The upper 3 bits of B^ are of no consequence in 



this instruction. BCD codes of 12 



8' 



32 



o, and 52p do not compare equal to zero. 

The BDP Condition register is set to the sign of field A (upper 2 bits of lowest 
order character). 
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SCAN, RL. NE 
Search Fielck A Right 
to Left for Inequality 



P + 1 
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unmodified address of the lowest or- 
der character in field A. R = r + [ B^] 

index register flag for field A 

If Br = 1 or 3, use index register B^ 

If Br = 2, use index register B^ 

If Bj. = 0, no indexing 

scan character which is compared 

against characters in field A 

number of characters to be searched 



Bits 00 through 18 of P + 1 and bits 12 through 17 
of P + 2 should be loaded with zeros. 

Instruction Description: Search field A from right to left beginning with the 6- 
bit character at location R. and RNI at P + 4 if a character is found that is not 
equal to the scan character , SC. If a character is not found that is not equal 
to the SC after the entire field defined by S2 has been searched, RNI at P + 3, 

Comments: K an unequal character comparison is found during the search, the 
number of characters searched is transferred to the lower 12 bits of B^, H all 
characters searched are equal to the SC, then (B^) = 8 r,. The upper 3 bits of B^ 



are of no consequence in this instruction, 
unequal comparison to zero. 



BCD codes 12o, 32o, and 52o cause an 



'8 



^8' 



8 



The BDP Condition register is set to the sign of field A (upper 2 bits of lowest 
order character). 
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SCAN, RL, NE, DC 
Search Field A Right 
to Left for Inequality, Delimited 
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r = unmodified address of the lowest or- 
der character in field A. R = r + [ B^.] 

Bj, = index register flag for field A 

If Bj. = 1 or 3, use index register B^ 
If Bj- = 2, use index register B^ 
If Bj. = 0, no indexing 

SC = scan character which is compared 
against characters in field A 

S2 = number of characters to be searched 
DC = 6 -bit delimiting character compared 
against the characters in field A 

Bits 00 through 18 of P + 1 should be loaded with 
zeros. 

Instruction Description: Search field A from right to left beginning with the 6- 
bit character at location R and RNI at P + 4 if a character is found that is not 
equal to the scan character, SC. If a character is not found that is not equal 
to the SC after the entire field defined by S2 has been searched, or if a charac- 
ter is found that equals the delimiting character, DC, RNI at P + 3 (If SC equals 
DC and an unequal comparison with field A occurs, RNI at P + 4). 

Comments: If an unequal character comparison is found during the search, the 
number of characters searched is transferred to the lower 12 bits of B . If all 
characters searched are equal to the SC, then (B^) = §2- The upper 3 bits of B^ 
are of no consequence in this instruction. BCD codes of 12o, 32g, and 52g cause 
an unequal comparison to zero. 

The BCD Condition register is set to the sign of field A (upper 2 bits of lowest 
order character). 
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Move Instructions 



Operation Field 


Address Field 


Interpretation 


MOVE, INT 


72 


S, r, s 


Move characters from r to s. 


MVE 


64 


r, Br, Si,s, Eg, S2 


Move field 


MVE, DC 


64 


r, Br, s, Bs, S2 


Move field with delimiting 


MVBF 


64 


r, Br, Si,s, Bg. h 


Move field and blank fill 


MVZF 


64 


r, Bj,, 8i,s, Bg, Sg 


Move field and zero fill 


MVZS 


64 


r, Br, S]^,s,Bs, ^2 


Move field and suppress zeros 


MVZS, DC 


64 


riBr, s, Bg, §2 


Move field and suppress zeros with 
delimiting 


ZADM 


67 


r, Br, Si, s, Bg, ^2 


Move field and add zeros 


FRMT 


64 


r, Bj,, Si,s, Bg, S2 


Move field and format with commas 
and decimal point 


EDIT 


64 


r, Br, h' s,Bs, S2 


Move field and perform complete 
COBOL edit 
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MOVE 
Move S 
Characters from r to s 



P+ 1 
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INT = "l" for interrupt upon completion 
s = first address of character block 

destination 
8 = field length of data block, 0-177g* 

characters 
r = first address of character block 

source 

Instruction Description: This instruction moves a block of characters from one 
area of storage to another. If Search/Move control is not busy, the buffered move 
operation commences while Main Control performs an RNI at P + 3. Main 
Control continues executing the main program while the move operation occurs 
simultaneously. If Search/Move control is initially busy. Main Control performs 
an RNI at P + 2 and the move operation does not occur. 

As a move operation progresses, r and s are incremented and S (number of 
characters) is decremented until S = 0. 128 characters or 32 words may be 
moved. When bits 00 and 01 of r and s are zero, and the field length is a multiple 
of four characters, data is moved word by word. This reduces the move time by 
75% over a character by character move. 

Register 21 of the Register File is reserved for the second instruction word 
which contains the first address of the character block source. Register 31 is 
reserved for the first instruction word which contains the first address of the 
character block destination. 

Figure 5-17 is a flow chart of steps that occur during a move operation. 



* = 1-1778 represents a field length of 1 to 127 characters; represents a field 
length of 128 characters. 
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I 



CO 



< 



Ol 
I 



o 
<! 

c+ 

c 
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o 





Load (P) 
into F 



Request 
Register 
File (RF) 



Await 
Priority 

if— 



Load (P + 1) 
into Data Bus 
Register (DBR) 



KIs Search/ IVIove\ N< 
Control Busy? J 



Transfer (DBR) 
to Register 21 



Transfer (F) 
to Register 31 



-o 



Release R.F. 
RNI at 
P + 2 



Establish Word 
or Character 
Move 




Establish First 
Word or 

Cliaracter 





Release R.F. 
Initiate Move 




Release Data 
Bus; RNI at 
P + 3 





ay- 



Move Control 
Genprates 
Block Control 
Request 



Await 
Priority 



-ih 



Read Up 
Register 21 
(P+ 1) 



Increment r 
by 1 for 
Character 
Move 



Decrement S 
by 1 for 
Character Move 



No Increment 
for First Word 
or Character 



Increment r by 
4 for Word 
Move 



Restore 
Register 21 



Read Up 
Register 31 
(P) 



Transfer 
r to S 



Increment S 
by 1 for 
Character Move 



Increment S 
by 4 for 
Wgrd Move 



No Increment 
For First Word 
or Character 



Decrement S 
by 4 for 
Word Move 



Restore Register 
31 (Save in Z 

register) 



Set Character 
Address in S^ 
for correct shift 



Request 

MCS 




Transfer (S^ 










Transfer (r 




bus 




























Retain Bus 






Transfer 
(Zl) to S^ 






Prior 


ity 











Request 
MCS f 



Priority 

—If — 



(S'^) to S 

Bus 



Transfer 
DBR to S 



Y,>oesS = 0?Vi^^ 



Terminiitt _ 
Move 



Iiilomipt 



Move F\e\d A to 
Field C 
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So 



unmodified address of the highest or- 
der character in field A. R = r +[ Bp] 

index register flag for field A 
If Br = 1 or 3, use index register B^ 
If Bj, = 2, use index register B^ 
If Bj- = 0, no indexing 
unmodified address of the highest or- 
der character in field C, S = s + [ Bg] 

index register flag for field C (same 
bit functions as Bj,) 
number of characters in field A to be 
moved 

number of available character posi- 
tions in field C 



Instruct ion Description : Move a field of up to 4095 
from field A to field C, left to right. 



6-bit alphanumeric characters 



Comments: If field A is longer than field C, the length of field C, S2. termi- 
nates the move operation and the remainder of the A field is not moved. If 
field C is longer than field A, the length of field A terminates the move opera- 
tion and the remainder of the C field remains unchanged. 

The BDP Condition register is set to the sign of field A if the sign character 
(lowest order character) is moved. It is set to OOg for a positive sign (or no sign 
transferred) and to 10 g for a negative sign. 
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MVE, DC 
Move Field A to 
Field C, Delimited 
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r = unmodified address of the highest or- 
der character in field A. R = r + [ Bj;.] 

Bj. = index register flag for field A 

If Bj. = 1 or 3, use index register B-*- 
If Bp = 2, use index register B2 
If Br = 0, no indexing 
s = unmodified address of the highest or- 
der character in field C. S = s + [Bg] 

Bg = index register flag for field C (same 
bit functions as Bf) 

S 2 = number of available character posi- 
tions in both field A and field C 

DC = 6 -bit delimiting character compared 
against the characters in field A 

Bits 18 through 23 of P + 2 should be loaded with 
zeros. 



Instruction Description: Move a field of up to 4095 
ters from field A to field C, left to right. 



6-bit alphanumeric charac- 



Comments: The length of field C, §2. terminates the move operation. If the 
delimiting character is recognized at any time during the character move, the 
operation is terminated after the delimit character has been moved. 

The BDP Condition register is set to the sign of field A if the sign character 
(lowest order character) is moved. It is set to OO2 for a positive sign (or no 
sign transferred) and to IO2 for a negative sign. 
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MV3F 

A^ove Field A to 

Field C and Blank Fill 
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r = unmodified address of the highest or- 
der character in field A. R = r + [ B^] 

Bj^ = index register flag for field A 

If Bj- = 1 or 3, use index register b1 
If Bj. = 2, use index register B^ 
If Bj;. = 0, no indexing 
s = unmodified address of the highest or- 
der character in field C. S = s + [Bg] 

Bg = index register flag for field C (same 
bit functions as Bj-) 

S 1 = number of characters in field A to be 
moved 

S 2 = number of available character posi- 
tions in field C 



Instruction Description : Move a field of up to 
ters from field A to field C, left to right. 



409 5 6-bit alphanumeric charac- 



Comments: If field A is longer than field C, the length of field C, S2. termi- 
nates the move operation and the remainder of field A is not moved. If 
field C is longer than field A, the remainder of field C is filled with blanks. 

The BDP Condition register is set to the sign of field A if the sign character 
(lowest order character) is moved. It is set to OOg for a positive sign (or no 
sign transferred) and to IO2 for a negative sign. 
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MVZF 

Move Field A fo Field 

C and Zero Fill 
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r = unmodified address of the highest or- 
der character in field A. R = r + [ B^.] 



Bj. = index register flag for field A 

If Bj- = 1 or 3, use index register B^ 
If B]^ = 2, use index register b2 
If Br = 0, no indexing 
s = unmodified address of the highest or- 
der character in field C. S = s +[Bs] 

Bg = index register flag for field C (same 
bit functions as Bj.) 

^ I = number of characters in field A to be 
moved 

S 2 = number of available character posi- 
tions in field C 

Instruction Description: Move a field of up to 4095 6-bit BCD numeric charac- 
ters from field A to field C, left to right. 

Comments: If field A is longer than field C, the length of field C, %2, terminates 
the move operation and the remainder of field A is not moved. If field C is lon- 
ger than field A, the remainder of field C is filled with zeros. The upper 2 bits 
of all field A characters are stripped (forced to zero) when moved to field C. 
Any field A character containing a 12g - 173 code is forced to zero when moved. 

The sign from field A (upper 2 bits of lowest order character) is always trans- 
ferred to the BDP Condition register and to the lowest order character in field C 
(this may be a zero-filled character), even if the A field is longer than the C field. 
A BCD fault is generated if one of the following conditions occur: 

1. Zone portion (upper 2 bits) of any character in field A (except sign charac- 
ter) does not equal zero. 

2. Numeric portion (lower 4 bits) of any character in field A contains a BCD 
code greater than llg, except the sign character where a 12g code is 
legal. 

3. The lowest order character (sign character) contains a 72g code. 

Operation continues despite any BCD fault. 
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MVZS 
Move Field A to Field 
C and Zero Suppress 
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r = unmodified address of the highest or- 
der character in field A. R = r + [ Bp] 



Br = index register flag for field A 

tf Br = 1 or 3, use index register B^ 
If Br = 2, use index register B^ 
If Br = 0, no indexing 
s = unmodified address of the highest or- 
der character in field C. S =? s + [ Eg] 

Bg = index register flag for field C (same 
bit functions as Br) 

S 1 = number of characters in field A to be 
moved 

$2 = number of available character posi- 
tion in field C 



Instruction Description: Move a field of up to 4095 6- bit alphanumeric characters 
in field A to field C, left to right, and replace all leading zeros occurring in field 
A with blanks in field C. 

Comments : If field A is longer than field C, the length of field C, S2. termi- 
nates the move operation and the remainder of the A field is not moved. In 
this case, the sign bits may be invalid (Sign bits are not checked or modified and 
consist of the upper two bits of the last character moved. ) 

If field C is longer than field A, the length of field A terminates the move oper- 
ation and the remainder of field C remains unchanged. 

The BDP Condition register is set according to the sign of the A field if the sign 
character is processed. 
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A4VZS, DC 

Move Field A to Field 

C and Zero Suppress, Delimited 
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r = unmodified address of the highest or- 
der character in field A. R = r + [ Bp] 

Bp = index register flag for field A 

If Br = 1 or 3, use index register B^ 
If Bj. = 2, use index register B^ 
If Bj. = 0, no indexing 
s = unmodified address of the highest or- 
der character in field C. S = s + [ Bs] 

Bg = index register flag for field C (same 

bit functions as B^) 
S 2 = number of available character posi- 
tions in both field A and field C 

DC = 6-bit delimiting character compared 
against the characters in field A 

Bits 18 through 23 of P + 2 should be loaded with 
zeros. 

Instruction Description: Move a field of up to 4095 6 -bit alphanumeric characters 
from field A to field C, left to right, and replace all leading zeros occurring in 
field A with blanks in field C. 

Comments : The length of field C, %2' terminates the move operation. If the 
delimiting character is recognized at any time during the character move, the 
operation is terminated after the delimit character has been moved. The sign of 
the newly formed C field may be invalid (Sign bits are not checked or modified 
and consist of the upper 2 bits of the last character moved. ) 

The BDP Condition register is always set to a positive sign (OO2). 
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Zero 

and Add Move 
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r = unmodified address of the lowest or- 
der character in field A. R = r + [ Bj,] 
Bj- = index register flag for field A 

If Br = 1 or 3, use index register B-*- 
If Bp = 2, use index register B2 
If Bjp = 0, no indexing 
s = unmodified address of the lowest or- 
der character in field C. S = s + [ Bg] 
Bg = index register flag for field C (same 



Si 
S 



2 



bit functions as Bj-) 
number of characters in field A to 
be moved 

number of available character posi- 
tions in field C 



Instruction Description : Move a field of up to 409 5 
ters from field A to field C, right to left. 



6-bit BCD numeric charac- 



Comments: If field A is longer than field C, the length of field C, S2, termi- 
nates the move operation and the remainder of the A field is not moved. If 
field C is longer than field A, the remainder of field C is filled with zeros. 

The algebraic sign of field A is obtained from the upper 2 bits of the lowest order 
character in field A. A lOg indicates a negative field and OO2, OI2' o^ -'■-'^2 ™di- 
cates a positive field. This sign is stored in the upper 2 bits of the lowest order 
character in field C. The BDP Condition register is also set to the sign of field C, 

Any field A character with a 12o - 17o code if forced to zero when moved, 

A BCD fault is generated if one of the following conditions occur: 

1. Zone portion (upper 2 bits) of any character in field A (except sign charac- 
ter) does not equal zero. 

2. Numeric portion (lower 4 bits) of any character in field A contains a BCD 
code greater than llg, except the sign character where a 12g code is legal, 

3. The lowest order character (sign character) contains a 72o code. 

Operation continues despite any BCD fault, 
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FRMT 

Move Field A 

and Format in Field C 
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r = unmodified address of the highest or- 
der character in field A. R = r + [ Bj,] 

Br = index register flag for field A 

If Bf = 1 or 3, use index register B^ 
If Br = 2, use index register B^ 
If Br = 0, no indexing, 
s = unmodified address of the highest or- 
der character in field C. S = s + [ Bg] 

Bg = index register flag for field C (same 
bit functions as B^.) 

S -|^ = number of characters in field A to be 
edited. (Values must be 2, 5, 108, 
133, 163, etc.) 

S 2 = number of characters in field C. 
Values of S2 must be 3, 6, 123^ 
163, 223, etc. and include decimal point 
and commas). 

Instruction Description: Move the numeric characters in field A from left to 
right into field C. replacing leading zeros with blanks and inserting -a comma 
after every three characters moved. A decimal point is inserted in the third 
lowest order position of the C field. 

Comments: Leading zeros in field A, together with normally inserted commas, 
are suppressed until the first non-zero character is encountered. Zero sup- 
pression terminates with the decimal point if only zeros are encountered. 

The sign of field A is recorded in the BDP Condition register but does not appear 
in the resultant C field. 

A BCD fault is generated if one of the following conditions occur; 

1. Zone portion (upper 2 bits) of any character infield A (except sign charac- 
ter) does not equal zero. 

2. Numeric portion (lower 4 bits) of any character in field A contains a BCD 
code greater than llg except the sign character, where a I23 code is 
legal. 

3. The lowest order character (sign character) contains a 723 code. 

4. Incorrect field length specified - a) the two fields are not aligned (Ex: 
S J = 2 and §2 = 6), b) illegal count used (Ex: %^ # 3, 6, 12g, 22g, etc. ). 

Operation continues despite any BCD fault. 
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EXAMPLE: 



\ - 'h 



S - l^E 



Field A 



This character address is specified by 'R ' 
0*^ 00007689 32 



Si specifies ISg 
characters in 
field A 



This character address 
is specified b 's' 



Field C 



$2 specifies I63 
characters (includ- 
ing decimal point 
and commas) in 
field C, The count 
progresses as 
follows: 



7, 6 8 9 . 3 2 

® ® ® ® ® ® ®® ® ® ® ® ® ® 



The leading zeros are 
removed, leaving six 
blanks in field C. 
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EDIT 

Move Field A 

and Edit in Field C 



P + 1 



P + 2 



23 18 17 16 



64 


1 


r 



23 21 20 19 18 17 16 



Br 



Be 



12 II 



00 



u 



z\ 



B, 



unmodified address of the highest or- 
der character in field A. R = r + [ B^] 

index register flag for field A 

If Br = 1 or 3, use index register B^ 

If Br = 2, use index register B^ 



If B, 



0, no indexing 



Be 



unmodified address of the highest or- 
der character in field C. S = s + [ B^ 

index register flag for field C (same 
bit functions as Bj.) 

%l = number of characters in field A to be 
edited 

$2 = number of characters in field C 

Instruction Description: Perform a complete formatted edit from left to right 
with up to 4095 characters in field C. The editing is performed character for 
character with respect to the COBOL type editing characters in field C. The 
resulting edited field is stored in field C. 

Comments: Programming consideration must be given to aligning the charac- 
ters in field A with the proper editing characters in field C, The COBOL type 
editing characters used in field C and applicable to this instruction are listed 
here with their descriptions. Any other character in the C field is recognized 

The BDP Condition register is set to the sign of field A. The conditions for a 
BCD fault are the same as for PRMT, with the exception of condition 4. 

Editing examples are listed following the character descriptions: 

EDITING CHARACTERS 
9 $ + - . , B CR DB Z * / 



] 



• Direct Characters 
9 



When the character 9 appears in the C field, it is replaced 
by the corresponding character in the A field. 
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• Insertion Characters: 

When an insertion character is specified in the C field, it remains in 
that character position in the edited field. The insertion characters 
are: 

$ + - . , B CR DB / 

$ When a single dollar sign is specified as the left- most symbol in 

a C field, it appears as the left -most character in the edited field. 
This character is included in the character count (S 2) of the 
edited field. 

+ When a plus sign is specified as the first or last symbol of a C 

field, a plus sign is inserted in the indicated character position 
of the edited data, provided the field of data is positive or is 
unsigned. If the data is negative, a minus is inserted in the in- 
dicated character position. The sign is included in the character 
count ( S 2) of the edited field. 

When a minus sign is specified as the first or last symbol of a 
C field, a minus sign is inserted in the indicated character posi- 
tion of the edited data, provided the field of data is negative. If 
the data is not negative, a blank is inserted in the indicated char- 
acter position. The sign or blank is included in the character 
count ( S 2) of the edited field. 

(decimal point) This character is used in a C field to represent 
an actual decimal point as opposed to an assumed decimal point. 
When used, a decimal point appears in the edited data as a char- 
acter in the sanae character position as it appears in the C field 
and it is included in the character count of the edited field. A 
picture of a report item can never contain more than one decimal 
point, actual or assumed. 

, When a comma is used in a C field, a comma is inserted in the 

corresponding character position of the edited data. It is in- 
cluded in the character count ( S2) of the edited field. 

(zero) When a zero is used in a C field, a zero is inserted in the 

corresponding character position in the edited field. It is in- 
cluded in the character count ( 83) of the edited field. 

B When the character, B, is used in a C field, a blank is inserted 

in the corresponding character position in the edited field. It is 
included in the character count (S 2) of the edited field. 

CR The combined characters (CR) represent a credit in accounting 

operations and may be specified only at the right end of a C field. 
The symbol is inserted in the last two character positions of the 
edited field, provided the value of the data is negative. If the data 
is positive or unsigned these last two character positions are set 
to blanks. Since this symbol always results in two characters 
(CR or blanks) it is included as two characters in the character 
count ( S 2) of the edited field. 
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DB The combined characters (DB) represent a debit and may be 
specified only at the right end of a C field. It has the same 
results as the credit symbol, using DB or blanks. 

/ (slash) When a slash (/) is used in a C field, a slash is inserted 

in the corresponding character position in the edited field. It is 
included in the character count ( S2) of the edited field. 

Replacement Characters: 

A replacement character in a C field suppresses leading zeros in data 
and replaces them with other characters in the edited data. The re- 
placement characters are: 

Z * $ + - 

replacement chi 
risk (*) may be 
including 



Only one replacement character may be used in a picture, although a 
Z or asterisk (*) may be used with any of the insertion characters 



$ + - 

Z One Z character is specified at the left end of a C field for each 

leading zero in the A field that requires suppression and replace- 
ment by a blank in the edited field. Z's may be preceded by one 
of the three insertion characters $ + or - and interspersed with 
the four insertion characters , , or B. Whether these insertion 
characters affect the result of the editing process depends on the 
nature of the data. 

Suppressing leading zeros and inserting blanks ceases when one of the 
following conditions exists: 

1. When the number of suppressed zeros equals the number of Z's 
specified in the C field, 

2. When the first non-zero digit character in the A field is 
encountered. 

3. When the position in the C field is reached where a decimal point 
insertion is specified. Zero suppression and blank replacement 
cannot continue beyond a decimal point, hence, a decimal point 
is never followed by blanks in an edited field. 

• If either a $ + - is specified before Z's, the character 
is inserted in the edited data regardless of leading zero 
suppression. 

If either a comma, B, or is encountered in the edit 

field before zero suppression has terminated, the charac- 
ter is not inserted in the edited data, but is suppressed 
and a blank is inserted. 

• In the special case where the edited data has a value of 
zero, the entire edited data is replaced by blanks if a 9 
does not appear in the edit picture. This special rule 
overrides the condition that zero suppression terminates 
when a decimal point is encountered. If one of the three 
insertion characters $ + - is specified but the value of 
the edited field is zero, a blank is inserted instead of the 
insertion character. 
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The asterisk (*) is specified in the same way and with the same 
results as the character Z, except that suppressed characters 
are replaced by asterisks instead of blanks. The rules for the 
Z character apply also to the use of the asterisk. 

If one more dollar sign ($) than the number of leading zeros to 
be suppressed is specified at the left end of a C field, this dollar 
sign acts as an insertion character. Each of the other dollar 
signs corresponds to a leading zero to be suppressed. This use 
of the dollar sign has the same results as described for the Z 
character, except that the dollar sign is inserted directly pre- 
ceding the first non- suppressed character. A dollar sign used 
in this way as a replacement character is known as a floating 
dollar sign as it virtually "floats" through all of the suppressed 
characters. 

If one or more floating dollar signs are specified in a C field, the 
edited data always contains a dollar sign whether or not any sup- 
pression occurs since one of the dollar signs is an insertion char- 
acter. Each dollar sign specified in a picture (including the in- 
sertion $) is included in determining the character count (S 2) of 
the edited field. 

When a plus- sign {+) is used as a replacement character, it func- 
tions' as a floating plus sign and is specified in the C field one 
more time than the nunaber of leading zeros to be suppressed. 
Its function is the san:>e as the floating dollar sign, with the fol- 
lowing exception: 

If the A field data is positive or unsigned a plus 
sign is inserted in the character position directly 
preceding the first non- suppressed character, ff 
the A field data is negative, a minus sign is in- 
serted in this character position in the edited field. 

When a minus sign is used as a replacement character it functions 
as a floating minus sign and is specified in the C field one more 
tinae than the number of leading zeros to be suppressed. Its func- 
tion is the same as the floating dollar sign and floating plus sign 
with the following exception: 

If the A field data is negative a minus sign is in- 
serted in the character position directly preceding 
the first non- suppressed character. If the value of 
the A field data is positive or unsigned, a blank is 
inserted in this position in the edited data instead 
of a minus sign. 
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TABLE 5-10. EDITING EXAMPLES 



UPPERMOST_ 

CHARACTER 

POSITIONS 



THE SIGN IS 
CONTAINED IN 
THE LOWEST ORDER 
CHARACTER. ONLY 
MINUS SIGNS ARE 
SHOWN HERE 



Field A Data 



-^4 8 



4 8 3 4 



4 8 3 4 




2 9 
2 9 



2 4 3 2 1 

2 4 3 2 1 

113 4 

113 4 

2 3 7 6 

2 3 7 6 

9 2 3 

9 2 3 



9 2 3 

8 2 4 

5 2 6 

3 2 6 5 



Field C 
Editing Data 

$99 

$99. 99 

9,999 

+999 

+999 

999- 

999- 

$BB999. 99 

$00999. 99 

99.99CR 

99.99CR 

99. 99DB 

99.99DB 

ZZ999 

ZZZ99 

ZZZZ.ZZ 

$***. 99 

$$$$9. 99 

---9. 99 

$$$. 99 



Resultant Field C 
Edited Data 




THE A FIGURE 
INDICATES A BLANK 
POSITION 
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Field C Resultant Field C 
Field A Data Editing Data Edited Data 

00001234 $ZZZ,ZZZ.99 $AAAAA12. 34 

00123456 $***,**9.99 $ * * 1 , 2 3 4 . 5 6 

12 3 4 5 6 3 4 $*>:<>;< ^ *>;<*. 99 $123,456. 34 

1 2^ -ZZZ,ZZZ - A A A A A 1 2 

12 3 4 5 6 2 4 $ZZZ , ZZ9. 99CR $123,456. 24CR 

12 3 4 $$$$,$$9.99 A A $ 1 , 2 3 4 . 

$$$$,$$$.99 AAAAAAAAAAA 

00001256 ,---.99DB AAAAA-12. 56DB 

1. Only one replacement character of the set Z * $ + and - can be used within 
a single editing C field even though it may be specified more than once. 

2. If one of the replacement characters Z or * is used with one of the 
insertion characters $ + or -, the plus sign or the minus sign may be 
specified as either the leftmost or rightmost character in the editing C 
field. 

3. A plus sign and a minus sign may not be included in the same editing C field. 

4. A leftmost plus sign and a dollar sign may not be included in the same 
editing C field. 

5. A leftmost minus sign and a dollar sign may not be included in the same 
editing C field. 

6. The character 9 may not be specified to the left of a replacement character. 

7. Symbols which may appear only once are: decimal point, CR, and DB. 

8. The decimal point may not be the rightmost character in an editing C field. 
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LBR 
Loud 6CR 



23 



18 17 1514 



00 



70 


6 


m 



m = storage address. Indexing not permitted. 

Instruction Description : Load the BCR and set interrupt recovery conditions 
within the BDP as defined by (m). The 24 bits of (m) have the following signi- 
ficance; 

POSITION FUNCTION 

00 and 01 Contents of the BCR 

02 Edit flag indicating a "D" (DB) or "C" (CR) character detected. 

03 Zero suppression operation in progress. 

04 Edit flag indicating a floating sign ($ + -) operation is in 
progress. 

05 Edit flag indicating a $ sign is forced. 

06 Edit flag indicating a + sign is forced. 

07 Edit flag indicating an * sign is forced. 

08 Edit flag indicating a floating character is forced. 

09 Operand equals zero. 

10 Signs of operands unlike for ADM or SBM, or incorrect on EDIT. 

11 Interrupt occurred during BDP operation. 

12 through 23 Number of characters or words for Field A already 
processed. 

Comments : The LBR instruction shoiold only be used when returning from an 
interrupt routine. The instruction is trapped if the BDP MODE switch is inactive 
or if the 3312 (BDP) is not present and the computer is operating in non- Executive 
mode or in Program State; it is a No-Op under these conditions in Monitor State. 



SBR 
Store (BCR) 



23 



18 17 1514 



00 



'» 


7 


m 



m = storage address. Indexing not permitted. 

Instruction Description: Store various operating conditions from within the BDP 
at address 'm'. Refer to the LBR instruction for the bit functions of (na). 

Comments: Execution of this instruction does not clear the operating conditions 
within the BDP. The instruction is trapped if the BDP MODE switch is inactive or 



5-155 



Rev H 



if the 3312 (BDP) is not present and the computer is operating in non- Executive 
mode or in Program State; it is a No- Op under these conditions in Monitor State. 
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6. SOFTWARE SYSTEMS 



GENERAL INFORMATION 

Control Data supports its lower 3000 Series Computers with a library of excellent 
standard software products effectively covering a wide range of computer 
applications. 

• Operating Systems exercise supervisory control 

• Languages are oriented toward programming needs 

• Utility routines perform tasks for user's programs 

• Applications systems are specialized programs 

This section briefly describes available software systems and also references 
obtainable documents. To obtain these documents, refer to the Literature 
Distribution Catalog for the correct Publication numbers. 



OPERATING SYSTEMS 

Operating systems provided by Control Data make efficient use of various hard- 
ware configurations. These operating systems provide autonaatic job monitoring 
and supervisory control during compilation, assembly, and execution of user's 
programs. Systems storage requirements are kept at a minimum and operator 
intervention reduced significantly by job stacking, automatic accounting and 
storage allocation, automatic assignment of input/output functions, and by opera- 
tor messages produced on the standard output comment unit. Operating systems 
include the following: 

• Real-Time SCOPE 

• MASTER 

• MSOS 

• SCOPE Utility Routines 
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Real-Time SCOPE 

An operating system which provides backgrounding, stacked job processing, and 
priority interrupt handling. Time is shared between a background program and 
the stacked jobs. The standard SCOPE features are included: I/O and status 
operations, debugging facilities, and library maintenance. 

Documents 

General Information 

Real-Time SCOPE Operator's Manual 

Real-Time SCOPE Reference 

MASTER 

A multiprogramming system that is adaptable to applications involving multi- 
access on-line input/ output with and without real time calculations as well as to 
conventional and batch processing applications. MASTER uses mass storage for 
system storage and temporary storage of user programs, as well as for storage 
of user files. MASTER allocates tasks to available equipment and handles 
communication among tasks. The tasks are processed on a priority basis. 

Documents 

General Information 
Reference 

MSOS 

Provides utilization of mass storage devices. The operating system, the related 
software packages and library, and user data areas are allocated to disk or 
similar storage. Time is shared between a background program and the stacked 
jobs. Background programs may operate in real time. The system also includes 
priority interrupt handling, I/O and status operations, debugging facilities, and 
library maintenance. 

Documents 

General Information 
MSOS Reference 
MSOS Operator's Manual 
PRE LIB MSOS 

SCOPE Utility Routines 

An open-ended peripheral processing package which allows transfer of data 
between peripheral units and storage media. 

Documents 
Reference 
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LANGUAGES 

Programmers can choose the language best suited to the needs of their particular 
problems. Control Data has implemented programming languages which range 
from machine mnemonics to problem -oriented systems which closely resemble 
the natural expressions in particular fields of application. The languages include: 

• FORTRAN 

• COBOL 

• ALGOL 

• COMPASS 

• Data Processing Package 

• Report Generator 

FORTRAN-32 

A versatile mathematical compiler. Most programs written in FORTRAN II and 
FORTRAN IV are compilable with FORTRAN- 32 . 

Documents 

General Information 
Reference 
Instant FORTRAN 
Library Routines 
Library Functions 

Mass Storage FORTRAN 

Provides all the features of FORTRAN-32 and allows compilation and execution 
using mass storage devices. 

Documents 

General Information 
Reference 

FORTRAN/ MASTER 
Instant FORTRAN 
Library Routines 
Library Functions 

COBOL 32 

A data processing language based on the specifications set forth in the DOD 
reference of COBOL- 61, Extended. This language provides fast compilation 
speeds and efficient object code. 
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Documents 

General Information 

Reference 

Compatible COBOL 

Version 2. Extensions and Revisions 

Instant COBOL 

COBOL 33 

Provides all the features of COBOL 32 and utilizes the Business Data Processing 
hardware during execution of the COBOL object programs. 

Documents 
Reference 

Mass Storage COBOL 

Provides all the features of COBOL 32 and uses mass storage for compilation. 
Version 2 of Mass Storage COBOL contains mass storage statements and allows 
object programs to use mass storage. 

Documents 

General Information 

Reference 

Version 2. Extensions and Revisions 

ALGOL 

A compiler accepting an algorithmic language defined in the ALGOL- 60 Revised 
Report in the Communication of the ACM, 1963, Vol. 6. Input/output procedures 
are those of the IFIP set and the complete ACM set. 

Documents 

General Information 

Reference 

Instant ALGOL 

Functional Description ALGOL Compiler 

Abnormal Object Time Termination Dump 

COMPASS-32 

A comprehensive assembly system, providing mnemonic machine operation codes, 
symbolic addressing, assembly- directing pseudo instructions, and programmer- 
defined macro instructions. 
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Documents 

General Information 

Compatible COMPASS Language Reference Manual 

COMPASS/ Tape SCOPE COMPASS/ Disk SCOPE 

Programming Guide 
Instant COMPASS 
COMPASS/Real-Time SCOPE. COMPASS/MSOS 

COMPASS-33 

An extension of COMPASS- 32 designed to process coding for the Control Data 3300. 

Documents 

Compatible COMPASS Language Reference Manual 

Instant COMPASS 

COMPASS/Real-Time SCOPE. COMPASS/MSOS 

COMPASS/MASTER 

Data Processing Package 

Consists of a set of input/output and file description macro instructions. The set 
also includes macros to perform certain data manipulation and mathematical 
functions. 

Documents 

General Information 
Reference 

Report Generator 

Facilitates the preparation of programs which produce a variety of reports from 
an input file. 

Documents 

General Information 
Reference 
Instant Report 



INPUT/OUTPUT 



Input/ output control routines are included in the software library to provide access 
to a number of different I/O media through efficiently preprogrammed library 
routines. 
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I/O control programs include: 

• RESPOND/ MSOS 

• MSIO 

• SIPP 

RESPOND/MSOS 

A multi-access software package which operates as a background program under 
MSOS and provides users at remote terminals with the ability to access files of 
information contained on mass storage at the central computer site. Files may be 
submitted to the operating system for foreground processing. Records within a file 
may be added, deleted, modified, or displayed by action of the terminal operator. 

MSIO 

A file oriented input/output system consisting of two sections. One section 
provides physical I/O features for mass storage files. The other section provides 
logical record processing facilities such as blocking, deblocking, buffering, 
updating, inserting, and deleting for files on mass storage. 

SIPP 

Enables simultaneous execution of data transfer operations involving several 
peripheral units. If permitted by the operating system, SIPP can operate as a 
background program. 

Documents 
Reference 



APPLICATIONS 

Applications programs are tested working programs which perform specialized jobs 
in industry, business, and research. Applications programs include: 

PERT/ TIME 

PERT/COST 

SORT 

Mass Storage SORT 

REGINA-I 

ADAPT 
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PERT/TIME 

Utilizes a time-oriented network structure to provide a variety of reports 
reflecting the actual and scheduled progress of a project. 

Documents 

PERT General Information 

Reference 

Version 2.0 Extensions and Revisions 

PERT/COST 

Utilizes a cost- oriented breakdown structure to provide a variety of reports on 
actual and estimated costs over the life of a project. 

Documents 

PERT General Information 
Reference 

SORT 

Produces a sequenced file of data records from random input. The internal phase 
makes use of the replacement selection sorting technique; the external phase may 
be either a balanced or poly-phase merge. The user has the option to enter own- 
code subroutines during the program. 

Documents 

General Information 
Reference 

Mass Storage SORT 

Similar to the tape SORT except that disk storage is used during intermediate 
merge processing. The SORT may optionally employ a tag sorting method. 

Documents 

General Information 
Reference 

REGINA-I 

A linear programming system; it provides an integer solution to the set of 
equations. 

Documents 

General Information 
Reference 

6-7 Rev.C 



ADAPT 

A system that prepares instructions for numerically controlled machine tools. 
The ADAPT language allows specification of the geometric properties of a part to 
be machined and the operations involved in producing the part. ADAPT is a subset 
of the more complex APT system. 

Documents 

General Information 
Reference 
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7. CONSOLE AND POWER CONTROL PANEL 




© Typewriter 

® Typewriter Switches 

® Data Interchange Display 

® Index, or LJA, or CIR 

Register 
® P Register or Page Index 

File Address 



® A and Q, or E Register 


® 


® Instruction State Register 


® 


(ISR) 


® 


® Operand State Register 


® 


(OSR) 


® 


® F or C Register 


® 


® Status Display 




Figure 7-1. 3300 Console 





ISR and OSR Entry Switches 
Step Rate Control 
Emergency Off Switch 
Access Keyboard Switches 
Console Condition Switches 
Breakpoint Switch 
Assembly 
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GENERAL INFORMATION 

The 3300 desk console shown in Figure 7-1 enables the conaputer operator to 
control and observe computer operation. This section describes the operator's 
controls and the significance of the visual indicators. Also included in this 
section is a description of the Power Control Panel. 



CONSOLE 

The console provides an operator with visual displays to monitor the current 
status of computer, controls for setting certain conditions and performing 
operations, and a typewriter for direct input and output communications with the 
computer. Each of these areas are described in the following pages to famil- 
iarize the operator with the functions of the console. 

Register Displays 

Figure 7-2 shows the display locations of the operational registers described in 
Section 1. Entering data into the Communication register. Instruction State 
Register, or Operand State register is described below. 




Figure 7-2. Register Display Area 
Instruction arid Communication Registers 

The Instruction register (F register) and Communication register (C register) 
share the same display area on the console. The F register is displayed when 
the access keyboard switches are inactive and the computer is not in the GO 
mode. The C register is displayed when data is being entered via the access 
keyboard switches. 

Data entered into the A or Q registers must first pass through the Communi- 
cation register. Starting with the uppermost digit, data is entered into the 
Communication register by first depressing a register switch and then depres- 
sing the numeric keyboard switches. A blue Active Digit indicator light is 
superimposed on each digit position of the Communication register as digit 
entry progresses. When data is entered into the B-*-, B^, B^^ or P regis- 
ters, the Active Digit indicator automatically starts at the fifth digit position of 
the Communication register. 
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Depressing the TRANSFER switch causes the data to be transferred from the 
Communication register to the designated register. Immediately depressing the 
TRANSFER switch again results in transferring all zeros to the register. 

Instruction State and Operand State Registers 

The contents of the ISR or OSR may be changed by first clearing the register(s) 
and then depressing binary position switches to form the desired octal number. 
The switches may be depressed simultaneously or individually. The white 
register clearing switch and blue binary position switches are shown in Figure 
7-3. 




Figure 7-3. ISR and OSR Display and Binary Entry Switches 
Data interchange Display 

The Data Interchange Display, shown in Figure 7-4, enables the console operator 
to determine the status of each of the eight I/O channels (0 through 7). Each 
channel has its own set of Input, Output, Reject, Interrupt,and Parity Error 
indicators. Transient conditions may not be seen on the display due to the re- 
sponse time of the indicators. 



INBIT OWmr REJECT , INTERMPT '^"J 
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Figure 7-4. Data Interchange Display 
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TABLE 7-1. DATA INTERCHANGE INDICATOR DESCRIPTIONS 



INDICATOR 

NAME 


FUNCTION 


INPUT 


Glows when data is being received by the computer on the 
channel indicated. 


OUTPUT 


Glows when data is being transmitted by the computer on the 
channel indicated. 


REJECT 


Glows when a Reject signal is received from a peripheral 
equipment on the channel indicated. 


INTERRUPT 


Glows when an Interrupt is received from a peripheral 
equipment on the channel indicated. Indicator glows until 
the interrupting condition is cleared. 


PARITY 
ERROR 


Glows when a transmission parity error has occurred on the 
channel indicated. Indicator glows until the condition is 
recognized. 



Status Display 

The Status Display provides the operator with visual indications of the internal 
status of the computer. Operating status, fault conditions, and physical mal- 
functions are the general status areas associated with the Status Display indi- 
cators. Figure 7-5 shows the arrangement of the indicators on the Status 
Display and the function of each indicator is described in Table 7-2. 
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Figure 7-5. Status Display 
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TABLE 7-2. STATUS DISPLAY INDICATOR DESCRIPTIONS 



INDICATOR 

NAME 


FUNCTION 


STORAGE 
ACTIVE 


Indicates a storage reference is in progress. Indicator is 
common to all storage modules. 


MONITOR 

STATE 


Indicates the computer is operating in the Monitor State of 
Executive mode. 


PROGRAM 

STATE 


Indicates the computer is operating in the Program State of 
Executive mode. 


INTERRUPT 
ENABLED 


Indicates the interrupt system has been enabled by executing 
an EINT (77. 74) instruction. 


READ NEXT 
INSTRUCTION 


Indicates the computer is reading the next instruction of the 
program it is currently executing. Usually referred to as 
the RNI cycle. 


READ 
ADDRESS 


Indicates the computer is reading the lower 18 bits at a 
storage location to form a new address for indirect addres- 
sing. Usually referred to as the RADR cycle. 


READ 
OPERAND 


Indicates the computer is reading a 24 -bit operand from 
storage for use with the instruction being executed. Usually 
referred to as the ROP cycle. 


STORE 
OPERAND 


Indicates the computer is storing a 24-bit operand that has 
been previously processed into a selected storage module. 
Usually referred to as the STO cycle. 


TEMP 
WARNING 


Indicates the temperature within the computer is abnormally 
high and is at least 80° F. 


ARITHMETIC 
OVERFLOW 


Indicates the capacity of the adder has been exceeded., Its 
capacity, including sign, is 24 or 48 bits for 24-bit pre- 
cision or 48-bit precision, respectively. 


DIVIDE 
FAULT 


The divide fault indicates a quotient, including sign, exceeds 
24 or 48 bits for 24-bit precision or 48-bit precision, 
respectively. Therefore, attempts to divide by too small a 
number, including positive and negative zero, result in a 
divide fault. During floating point division, a divide fault 
occurs if division by zero or by a number that is not in 
floating point format is attempted. If the divisor is not 
properly normalized a divide fault may also occur. Refer to 
Appendix B for a description of normalization. 


EXPONENT 
FAULT 


Indicates either an exponent overflow (> + 1777g) or an ex- 
ponent underflow « - 17778) ^as occurred during a floating 
point arithmetic operation. 



(Continued) 
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TABLE 7-2. STATUS DISPLAY INDICATOR DESCRIPTIONS (Cont'd) 



INDICATOR 

NAME 



BCD 

FAULT 



ILLEGAL 
WRITE 



PARITY 
ERROR 



TERMINATOR 
FAULT 



CIRCUIT 
BREAKER 



TEMP 
HIGH 



FUNCTION 



Indicates a BCD fault has occurred within the BDP module 
or a SBCD (77. 72) instruction has been executed. Refer 
to Section 4, Interrupt System, for additional information. 



Indicates an attempt has been made to write into a pro- 
tected storage location or read from certain locations 
while operating in Executive mode. Refer to Section 4, 
Interrupt System, for additional information. 



Indicates a parity error occurred during a memory 
reference. Transmission parity errors do not affect this 
indicator. 



Indicates that the internal terminator power supplies are 
not functioning properly. 



Indicates that one or more of the power system circuit 
breakers are open. 



If the TEMP WARNING indicators are glowing and an 
absolute temperature of 110° F is exceeded, the computer 
automatically shuts off logic power. The TEMP HIGH 
indicator for the particular computer section continues 
to glow until the temperature drops below the absolute 
limit. Secondary power must be manually reapplied before 
normal operation can resum^e. 



Switches and Controls 



Condition Switches 



The condition switches are used mainly to set various operating and program- 
ming conditions. These 24 switches are located on both sides of the access 
keyboard switches and are shown in Figure 7-6 and described in Table 7-3. 
The typewriter control switches, located on the extreme left side of the console 
are described later in this Section. 
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Figure 7-6. Condition Switches 
TABLE 7-3. CONDITION SWITCHES DESCRIPTION 



SWITCH 

NAME 


FUNCTION 


SELECT 
JUMP (1-6) 


Switches are actuated in accordance with programs 
utilizing the Selective Jump instruction (SJl-6 OOj). 


SELECT 
STOP 


Stops the computer when the SLS (77. 70) instruction is read. 
When the computer enters the GO mode again^ the program 
resumes with the next instruction. 


PARITY 
STOP 


Causes the computer to halt when a storage parity error is 
detected. 


PARITY 
INTERRUPT 


Causes the computer to process the interrupt subroutine 
when a storage parity error is detected. Refer to Section 
4, Interrupt System, for additional information. 


EXECUTIVE 
MODE 


Permits the computer to operate in the Executive mode. 
Initial state of Executive mode is always the Monitor State. 
Reactuating this switch permits the computer to operate in 
the non-Executive mode. 


AUTO 
LOAD 


If the computer has been Master Cleared and the AUTO LOAD 
switch is actuated, the computer automatically jumps to 
address 77740 if in the non-Executive mode or address 
003700 in Executive mode and executes the instruction stored 
there. Refer to Auto Load/Auto Dump in Section 3. 


AUTO 
DUMP 


This switch perform.s the same function as the AUTO LOAD 
switch with the exception of jumping to address 77760 if in 
the non-Executive mode or address 003740 in Executive 
mode. 



(Continued) 
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TABLE 7-3. CONDITION SWITCHES DESCRIPTION (Cont'd) 



SWITCH 

NAME 



BDP MODE 

(Business 

Data 
Processor) 



AUTO 

STEP 



STORAGE 
CYCLE STEP 



INSTRUCTION 
STEP 



THERMOSTAT 
BYPASS 



DISABLE 
STO PROTECT 



ENTER AUTO 
PROGRAM 



LJA 

(Last Jump 

Address) 

CHANNEL 

INDEX REG 

(Channel Index 

Register) 



DISABLE 
ADVANCE P 



FUNCTION 



Actuating this switch with the BDP module in the system 
permits the BDP to directly execute the business oriented 
instructions. If the switch is not On, these instructions are 
trapped. Refer to Section 5, Instructions, for a list of the 
BDP instructions. 



Permits instructions to be executed in a slow speed GO 
mode. The speed (3 to 50 instructions per second) is reg- 
ulated by a variable Step Rate control on the Upper Console 
Switch Panel. ■ _____ 



MANUAL 
INTERRUPT 



INTERNAL 
CLEAR 



EXTERNAL 
CLEAR 



Enables the operator to step through an instruction one 
storage cycle at a time, i.e. , RNI, RADR, ROP, or STO. 



Enables the operator to execute a program, instruction by 
instruction. One instruction is executed each time the 
switch is pressed. 



Allows computation to proceed regardless of abnormal 
temperatures within the computer. 



Disables the protection feature of the 15 storage protect 
switches. This switch has.no effect on the protected 
Auto Load and Auto Dump or program protected storage 
areas. 



Allows the operator to enter the Auto Load and Auto Dump 
storage areas with different data. 



Actuating this momentary switch when the conputer is 
stopped causes the storage address of the last jump 
instruction to be displayed on the console. 



Pressing this switch when the computer is stopped causes 
the contents of the 3 -bit Channel Index register to be dis- 
played. 



Prevents the P register from being incremented. When the 
GO switch on the keyboard is pressed, the same instruction 
is repeatedly executed. 



Forces the computer into an interrupt routine if the com- 
puter is in the GO mode. If the computer is stopped when 
the switch is pressed, it goes into an interrupt routine as 
soon as the GO switch is pressed. 



Master clears internal conditions and registers. 



Master clears all external equipments and the I/O 
channels. 
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Access Keyboard 

Figure 7-7 shows the access keyboard switches, used for manually entering 
and retrieving data from the computer and controlling its operation. Table 7-4 
describes the individual keyboard switch functions. 

Upper Console Switch Panel 

The upper console switch panel shown in Figure 7-8 is used for: 
e Selecting Index register B^ , B^^ or B^ for display 
s Operating the Breakpoint switch 
Entering data into the ISR or OSR 

• Adjusting the Step Rate control 

• Immediately removing computer power in the event of an 
emergency by depressing the EMERGENCY OFF switch 

The Index register switches on the access keyboard are used for entering data. 
To display one of the three index registers, the appropriate upper console index 
register switchmustbe depressed. A. complete description of the Breakpoint switch 
follows the access keyboard switch descriptions. 
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Figure 7-7. Access Keyboard Switches 
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Figure 7-8, Upper Console Switch Panel 



TABLE 7-4, ACCESS KEYBOARD SWITCHES 



SWITCH 

NAME 


FUNCTIONS 


A 


Causes both A and Q to be displayed, but permits entry 
only into A, 


Q 


Causes both A and Q to be displayed, but permits entry 
only into Q. 


E 


Causes E-q and El to be displayed. Manual entry is not 
possible. 


P 


Enables an address to be manually entered from the key- 
board into the P register. 


Bi,B2,or Bg 


Enables data to be manually entered into Index registers 
B1 , b2, or b3 from the keyboard. Appropriate Index 
register switch on the upper console switch panel must be 
depressed for register display. 


EN 
(ENTER) 


Permits data to-be manually entered into storage while the 
computer is stopped. First address of sequence must be 
previously entered into P. Pressing the TRANSFER 
switch advances P. 


ENTER 
PF 


Permits data to be manually entered into the Page Index 
File while the computer is stopped. First address of 
sequence must be previously entered into the lower 7 bits 
of the P register. 


SW 
(SWEEP) 


Permits unexecuted instructions to be read from consecu- 
tive storage locations. First address of sequence must be 
previously entered into P. Pressing the TRANSFER switch 
advances P. 


SWEEP 
PF 


Permits page indexes to be read from consecutive Page 
Index File locations. First address of sequence must be 
previously entered into the lower 7 bits of 'the P register. 


SW/EN 

CONT 

(SWEEP/ ENTER 

CONTINUOUS) 


Enables Sweep or Enter operations to proceed continuously 
through storage or the Page Index File without pressing the 
TRANSFER switch. 
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TABLE 7-4. ACCESS KEYBOARD SWITCHES (Cont'd) 



SWITCH 
NAME 


FUNCTION 


WRITE STO 

(WRITE 
STORAGE) 


Permits keyboard entry into the storage location specified 
by the thumb-wheel switches. Entry occurs each time the 
TRANSFER switch is pressed whether the computer is in 
the GO mode or stopped. 


READ 

STO 

(READ STORAGE) 


Permits the contents of the storage register location 
specified by the thumb-wheel switches to be displayed. The 
display rate is determined by the Step Rate control. 


GO 


Starts the program execution at the address specified by 
the P register. Not used for Sweep or Enter operations. 


STOP 


Stops the computer at the end of the current instruction. 


THROUGH 7 


These switches, when pressed one at a time, allow entry 
of that particular digit into the Communication register. 


TRANSFER 


Transfers data in the Communication register to a selected 
register or storage location. 


MC 
(MASTER CLEAR) 


Performs both an internal and external clear. Disabled 
when GO switch is depressed and the computer is in the 
GO mode. 


KYBD CLR 
(KEYBOARD 
CLEAR) 


Clears the Communication register. 


KYBD 

OFF 

(KEYBOARD 

OFF) 


Deactivates all access Keyboard controls. 



Breakpoint Switch 

The Breakpoint switch is a six- section, eight-position, thumb-wheel switch. 
The left-hand wheel selects the operating mode, and the other five wheels 
specify a register number or storage address. There are four mode positions 
on the mode selector switch with an OFF position between each mode; these 
modes are BPI, BPO, REG, and STO. 

BPI and BPO Modes : The address on the S Bus is continually compared with 
the instruction or operand address specified by the Breakpoint digit switches. 
When the selector switch is set to BPI, the computer stops if these values be- 
come equal during an RNl (Read Next Instruction) sequence. When the mode 
selector switch is set to BPO, the computer stops if these values become equal 
during an ROP (Read Operand) or STO (Store) sequence. 
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REG and STO Modes: In these two modes, the operator may either monitor the 
contents of a register location or storage address specified by the thumb-wheel 
digit switches, or he may store a word in these locations. To monitor a storage 
location: 

Set the mode selector to REG (register file location) or STO (storage). 

Set the Breakpoint switch to the desired register number or storage 

address. 

• Press the READ STO switch on the keyboard. 

• Adjust the Step Rate control to vary the display rate. 

The register or storage contents are repeatedly displayed in the Communication 
register at the selected repetition rate until another keyboard button is pressed 
to release READ STO. To write a word in storage: 

Set the mode selector to REG or STO. 

Set the Breakpoint switch to the desired register number or storage 

location. 

• Press the WRITE STO switch on the keyboard. 

• Enter data into the Communication register by depressing the numeric 
switches and finally the TRANSFER switch. 

The data is entered into the desired storage location or Register File location 
at the end of the instruction that is currently being executed by the computer. 
Pressing any other register or mode selector switch releases WRITE STO 
operation. 

Emergency Off Switch 

This red momentary switch is used to remove power from the whole computer 
system in case of a fire or other emergency. It should not be used for a normal 
power shutdown. Refer to the SOURCE POWER OFF switch description in the 
Power Control Panel description of this section. 

Console Loudspeaker Volume Control 

The console loudspeaker and its associated volume control are mounted under- 
neath the console table. The loudspeaker receives its input from the upper 3 bits 
of the A register. Sound is produced when one or more of these bits are toggled 
at an audio frequency. Loudspeaker volume is controlled by rotating the volume 
control knob. 

Examples of Keyboard Switch Functions ; 
1. To enter data into the A register: 
a. Depress the A register switch. 
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b. Enter all eight digits of the Communication register by depressing 
the appropriate numeric key switches.* 

c. Depress the TRANSFER switch. 

d. Depress the KEYBOARD OFF switch. 

2. To enter data into the Q register: 

Depress the Q register switch and repeat steps b through d 
of example 1. 

3. To enter the Program Address Counter (P register) with a 
specific address: 

a. Depress the P register switch. 

b. Enter the lower five digits of the Communication register by 
depressing the appropriate numeric key switches. 

c. Depress the TRANSFER switch. 

d. Depress the KEYBOARD OFF switch. 

4. To enter an operand at a specific address:** 

a. Perform example 3. 

b. Depress the EN switch. 

c. Enter all eight digits of the Communication register by 
depressing the appropriate numeric key switches. 

d. Depress the TRANSFER switch. 

e. The count in the Program Address Counter has now incre- 
mented by one. If data is to be entered into this mem.ory 
location, repeat steps c and d for as many succeeding 
entries as required. 

f. Depress the KEYBOARD OFF switch when all data has 
been entered into the successive group of memory 
locations. 

5. To read an operand from a specific storage address: 

a. Perform example 3. 

b. Depress the SW switch. 

c. Depress the TRANSFER switch. 

d. The contents of the specified storage address are now displayed 
in the Communication register. (The Program Address Counter 
is not incremented when the TRANSFER switch is initially 
depressed.) 



:=If all eight digit positions of the Communication register are not entered 
before the Transfer switch is depressed, zeros will be entered into the 
remaining digit positions. 

:^The Breakpoint switch may be used in lieu of this operation. (Refer to 
Example d. Figure 7-9.) 
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e. If the TRANSFER switch is again depressed, the Program 
Address Counter is incremented by one, and the contents of 
the new address are displayed. 

f. Depress the KEYBOARD OFF switch when all of the desired 
memory locations within a successive group have been 
examined. 

NOTE 

Step 5 only permits the operator to examine 
the contents of specific storage locations. 
The instructions are not executed during 
this operation, 

6. To enter zeros or another operand into all storage locations: 

a. Depress the EN switch. 

b. Enter all eight digits of the Communication register by 
depressing the appropriate numeric key switches, 

c. Depress the SW/EN CONT switch. 

d. Depress the STOP switch. 

e. Depress the KEYBOARD OFF switch. 

7. The following procedure is applicable for sweeping storage during 
certain maintenance routines: 

a. Depress the SW switch. 

b. Depress the SW/EN CONT switch. This switch remains 
engaged until the STOP switch is depressed. 

c. Depress the STOP switch. 

d. Depress the KEYBOARD OFF switch. 

8. To enter a 12 -bit operand into a specific Page Index File (PIF) 
address: 

a. Set P to a specific PIF address (000-177) as outlined in 
example 3. (Only the lower 7-bits of P are recognized.) 

b. Depress the ENTER PF switch. 

c. Enter the lower four digits of the Communication register by 
depressing the appropriate numeric key switches. 

d. Depress the TRANSFER switch. 

e. The PIF address in the Program Address Counter has now 
incremented by one. If data is to be entered into this PIF 
location, repeat steps c and d for as many succeeding 
entries as required. 

f. Depress the KEYBOARD OFF switch when all data has been 
entered into the successive group of PIF locations, 

9. To read an index from the PIF: 

a. Perform step a of example 8. 

b. Depress the SWEEP PF switch 
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c. Depress the TRANSFER switch. 

d. The specified index of the PIF is now displayed in the lower 
12-bits of the Communication register. (The Program Address 
Counter is not incremented when the TRANSFER switch is 
initially depressed.) 

e. If the TRANSFER switch is again depressed, the Program 
Address Counter is incremented by one and the index of the 
new PIF address is displayed. 

f. Depress the KEYBOARD OFF switch when all of the desired 
indexes within a successive group have been examined. 

10. To enter zeros or another operand into all indexes of the PIF: 

a. Depress the ENTER PF switch 

b. Enter the lower four digits of the Communication register by 
depressing the appropriate numeric key switches. 

c. Depress the SW/EN CONT switch. This switch remains 
engaged until the STOP switch is depressed. 

d. Depress the KEYBOARD OFF switch. 

11. The following procedure is applicable for sweeping all indexes of 
the PIF during certain maintenance routines: 

a. Depress the SWEEP PF switch 

b. Depress the SW/EN CONT switch. This switch remains 
engaged until the STOP switch is depressed. 

c. Depress the STOP switch. 

d. Depress the KEYBOARD OFF switch. 



Examples of Console Switch Functions: 



To enter a special routine into the non-Executive mode Auto Load 
storage area: 

a. Depress the MC (Master Clear) keyboard switch. 

b. Holding down the keyboard STOP switch, depress the AUTO 
LOAD switch. Release both switches. The P register should 
now read 77740. (Holding the STOP switch down prevents the 
computer from entering the GO mode and executing the pre- 
vious Auto Load routine. ) 

c. Depress the ENTER AUTO PROGRAM switch. 

d. Depress the keyboard EN switch. 

e. Enter the first instruction of the new routine at address 
77740 by depressing the appropriate numeric key switches. 

f. Depress the keyboard TRANSFER switch. 

g. Repeat steps e and f for addresses 77741 through 77757. 

h. Depress the MC switch. This clears the registers and cancels 
the ENTER AUTO PROGRAM function. 
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i. Depress the KEYBOARD OFF switch. 

2. To enter a special routine into the non-Executive mode 
Auto Dump storage area: 

Repeat steps a through i of example 1 using the AUTO DUMP 
switch and filling the storage area covered by addresses 77760 
through 77777. 

3. To execute the Auto Load routine: 

a. Depress the keyboard MC switch. 

b. Depress the AUTO LOAD switch. The computer automatically 
executes the Auto Load routine and stops when a stop or halt 
instruction is recognized. The Auto Load function is auto- 
matically cleared when the firstl/O operation is completed. 

4. To execute the Auto Dump routine: 

Perform steps a and b in example 3 but use the AUTO DUMP 
switch instead of the AUTO LOAD switch. 

5. To execute a program at a Auto Step rate: 

a. Set the P register to the first address of the program to be 
executed. 

b. Depress the AUTO STEP switch. 

c. Adjust the STEP RATE display control. 

d. Depress the AUTO STEP switch again to cancel the function 
and stop program execution. The only way to exit from the 
Auto Step mode is to depress the AUTO STEP switch again. 
In the Auto Step mode , halt and jump instructions are 
executed.but the computer does not stop. Neither will program 
execution be affected by depressing the STOP switch. The 
computer continues cycling through memory until the AUTO 
STEP switch is again depressed, 

NOTE 

To load or execute a subroutine in the Auto 
Load or Auto Dump areas while in Executive 
mode, perform the same operations as for 
non-Executive mode except that the addresses 
for the respective areas will be as follows: 

Auto Load: 003700 through 003737 

Auto Dump: 003740 through 003777 
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EXAMPLE A 



EXAMPLE B 





The Breakpoint switch is inoperative 
whenever an OFF designator is dis- 
played. An OFF designator separ- 
ates the REG, STO, BPI and BPO 
positions. 



During the normal execution of a 
program, the computer stops when 
an RNI is attempted at memory lo- 
cation 05443. A jump to this loca- 
tion also causes the computer to stop. 
If the program references memory 
location 05443 for an operand, the 
computer ignores the Breakpoint 
switch. 



EXAMPLE C 



EXAMPLE D 





The computer stops only when an 
attempt is made to read or store an 
operand at address 00413. 



If the WRITE STO switch on the key- 
board is depressed and data has been 
entered into the Communication reg- 
ister, the data is transferred to 
memory location 00104 when the 
TRANSFER switch is depressed. 



Figure 7-9. Breakpoint Switch Examples 
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EXAMPLE E 



EXAMPLE F 




\ 2 7 4 



If the WRITE STO switch on the 
keyboard is depressed and data has 
been entered into the Communi- 
cation register J the data will be 
transferred to register 77 when the 
TRANSFER switch is depressed. 
(Only the lower two digits are re- 
cognized when the designator switch 
is in the REG position. The pro- 
grammer must use caution when 
writing into the Register File to 
prevent destruction of other data. 
Refer to Section 1, Table 1-3.) 



If the READ STO switch on the key- 
board is depressed, the contents of 
memory location 27004 are displayed 
in the Communication register at a re- 
petition rate determined by the Step 
Rate control. (If the memory location 
depicted by the Breakpoint switch ex- 
ceeds the storage capacity of the sys- 
tem, the computer selects the address 
that corresponds to the storage capa- 
city of the system. ) 



EXAMPLE G 




If the READ STO switch on the key- 
board is depressed, the contents of 
register 22 are displayed in the 
Communication register at a repe- 
tition rate determined by the Step 
Rate control. (Only the lower two 
digits are of consequence when the 
REG designator is displayed. In 
this case register 22, the real time 
clock, is being referenced.) 



Figure 7-9. Breakpoint Switch Examples (Cont'd) 
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Typewriter 

The console typewriter is an on-line input/output (I/O) device; i.e. , it requires 
no connection to a communication channel and no function codes are issued. The 
typewriter receives output data directly from storage via the lower 6 bits of the 
Data Bus. Inputs to storage are handled in the same manner. 

Used in conjunction with Block Control and the Register File, the typewriter may 
be used to enter a block of internal binary-coded characters into storage and to 
print out data from storage. The two storage addresses that define the limits of 
the block must be stored in the register file prior to an input or output operation. 
Register 23 contains the program state number and the initial character address 
of the block. Register 33 contains the last character address, plus one (refer to 
Section 1, Table 1-1 notes for Registers 23 and 33 operand formats). Because 
the initial character address is incremented for each storage reference, it always 
shows the address of the character currently being stored or dumped. Output 
operations occur at the rate of 15 characters per second. Input operations are 
limited by the operator's typing speed. 

The console typewriter control switches are showninFigure 7-10 and their 
functions are described in Table 7-5. 



ENCODE 
UNCTION 



FINISH 



LiR 



Figure 7-10. Console Typewriter Control Switches 
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The general order of events when using the console typewriter for an input or 
output operation is: 

• Check status 

• Set registers 23 and 33 of the Register File to the appropriate 
addresses 

• Set tabs, margins and spacing; turn on typewriter 

• Clear 

• Type out or type in 

Status Checking 

The programmer may wish \o check the status of the typewriter before pro- 
ceeding. This is done with the Pause instruction. Status response is returned 
to the computer via two status lines. 

The typewriter control transmits two status signals that are checked by the Busy 
Comparison Mask using the Pause instruction. These status signals are: 

Bit 09 Type Finish 

Bit 10 Type Repeat 

An additional status bit appears on sense line 08. This code is Type Busy and 
is transmitted by block control in the computation section when a typewriter 
operation has been selected. If the programmer is certain of the status of the 
typewriter, this operation may be omitted. 

Set Registers 23 and 33 

Registers 23 and 33 define the limits of the typewriter I/O operation. These 
registers are set by instruction or by entering the registers via the Breakpoint 
switch. 

Set Tabs, Margins, and Spacing 

All tabs, margins, and paper spacing must be set manually prior to the input or 
output operation. A tab may be set for each space on the typewriter between 
margins. 

Clear 

There are three types of Clears which may be used to clear all conditions (ex- 
cept Encode Function) existing in the typewriter control. These are: 

• Internal Clear or a Master Clear 

This signal clears the typewriter control and sets the type- 
writer , to lower case. 
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TABLE 7-5. CONSOLE TYPEWRITER SWITCHES AND INDICATORS 



SWITCH 


SWITCH (S) 
INDICATOR (I) 


FUNCTION 


ENCODE 
FUNCTION 


S/I 


This switch enables the typewriter to send 
to storage the special function codes for 
backspace, tab, carriage return, upper- 
case shift, and lower-case shift. 


TYPE 
LOAD 


S/I 


This switch allows the computer to receive 
a block of input data from the typewriter. 
The TYPE LOAD indicator remains on until 
either the FINISH, REPEAT, or CLEAR but- 
ton is pressed, or until the last character of 
the block has been stored. If the program 
immediately reactivates the typewriter, it 
may appear that the light does not go off. 


TYPE 
DUMP 


S/I 


This switch causes the computer to send 
data to the typewriter for print -out. It is a 
momentary contact switch that is illuminated 
until the last character in the block has been 
printed or the CLEAR button is pressed. 


REPEAT 


S/I 


This switch is pressed during a Type Load 
operation to indicate that a typing error 
occurred. This switch deactivates busy 
sense line 10 (see PAUS instruction). If 
the computer does not respond, this light 
remains on. 


FINISH 


S/I 


This switch is pressed during a Type Load- 
operation to indicate that there is no more 
data in the current block. This action is 
necessary if the block that the operator 
has entered is smaller than the block de- 
fined by registers 23 and 33. This switch 
also deactivates busy sense line 09. If the 
computer does not respond, this light 
remains on. 


CLEAR 


S/I 


This switch clears the typewriter controls 
and sets the typewriter to lower case but 
does not cancel the ENCODE FUNCTION 
switch. 
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• Clear Channel, Search/Move Control, or Type Control 
instruction (77,51). 

This instruction selectively clears a channel, the S/M control, 
or, by placing a "l" in bit 08 of the instruction, the typewriter 
control, and sets the typewriter to lower case, 

• Clear Switch on Typewriter 

This switch clears the typewriter control and sets the 
typewriter to lower case. 

Type In and Type Load 

Executing the CTI (77, 75) instruction or pressing the TYPE LOAD switch on the 
console or typewriter permits the operator to enter data directly into storage 
from the typewriter. When the TYPE LOAD indicator on the console glows, the 
operator may begin typing. The Encode Function switch must be depressed to 
enable backspace, tab, carriage return, and case shifts to be transmitted to the 
computer during a typewriter input operation. 

Input is in character mode only. As each character is typed, the information 
is transmitted via the Data Bus to the storage address specified by block control. 
This address is incremented as characters are transmitted. When the current 
address equals the terminating address, the TYPE LOAD indicator goes off and 
the operation is terminated. Data is lost if the operator continues typing after 
the TYPE LOAD indicator goes off. 

Type Out and Type Dump 

The typewriter begins to type out when the computation section executes a CTO 
(77. 76) instruction,or when the operator presses the TYPE DUMP switch on the 
console. Single 6-bit characters are sent from storage to the typewriter via the 
lower 6 bits of the Data Bus. When the current address equals the terminating 
address, the TYPE DUMP indicator goes off and the operation is terminated. 

During a Type Out operation, the keyboard is locked to prevent loss of data in 
the event a key is accidentally pressed. 

Table 7-6 lists the internal BCD codes, typewriter printout and upper-or lower- 
case shift that applies to the console typewriter. All character transmission 
between the computation section and the typewriter is in the form of internal 
BCD. The typewriter logic makes the necessary conversion to the machine 
code. 
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NOTE 

Shifting to upper case (57) or lower case (32) 
is not necessary except on keyboard letters 
where both upper and lower cases are avail- 
able. The standard type set has two sets of 
upper case letters and no lower case letters. 
This eliminates the need for specifying a 
case shift. 



TABLE 7-6. CONSOLE TYPEWRITER CODES 



PRINT- 


CASE 


INTERNAL 


PRINT- 


CASE 


INTERNAL 


OUT 




BCD CODE 


OUT 




BCD CODE 





L* 


00 


- 


L 


40 


1 


L 


01 


J 


U or L 


41 


2 


L 


02 


K 


Uor L 


42 


3 


L 


03 


L 


U or L 


43 


4 


L 


04 


M 


U or L 


44 


5 


L 


05 


N 


U or L 


45 


6 


L 


06 


O 


Uor L 


46 


7 


L 


07 


P 


U or L 


47 


8 


L 


10 


Q 


U or L 


50 


9 


L 


11 


R 


Uor L 


51 


± 


u* 


12 


° (degree) 


U 


52 


= 


L 


13 


$ 


u 


53 


II 


U 


14 


* 


u 


54 


: 


U 


15 


# 


u 


55 


f 


L 


16 


% 


u 


56 


? 


U 


17 


(Shift to UC) 




57 


+ 


u 


20 


(Space) 




60 


A 


Uor L 


21 


/ 


L 


61 


B 


Uor L 


22 


S 


U or L 


62 


C 


Uor L 


23 


T 


Uor L 


63 


D 


Uor L 


24 


U 


U or L 


64 


E 


U or L 


25 


V 


U or L 


65 


F 


Uor L 


26 


W 


U or L 


66 


G 


Uor L 


27 


X 


U or L 


67 


H 


U or L 


30 


Y 


U or L 


70 


I 


U or L 


31 


z 


U or L 


71 


(Shift to LC) 




32 


& 


U 


72 




U and L 


33 


> 


U and L 


73 


) 


U 


34 


( 


U 


74 


I 


L 


35 


(Tab) 




75 


@ 


U 


36 


(Backspace) 




76 


! 


L 


37 


(Carriage 
Return) 




77 



L = Lower Case; U = Upper Case 
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POWER CONTROL PANEL 



The Power Control Panel module shown in Figure 7-11 controls the logic power 
supplied to the CPU and the first I/O module. Adjusting the +20 and -20 con- 
trols for 0% indication on. their respective meters provides exactly the proper 
operating power. The following illustration shows which part of the computer 
the Compute One and Compute Two controls govern. 



FLOATING 

POINT 
MODULE 



I 




I/O 
MODULE 



I 



"V 
POWER 

CONTROLLED 

BY 

COMPUTE 2 



v 

POWER 
CONTROLLED 

BY 
COMPUTE I 



The two main circuit breakers must both be On before the system CPU is 
operative. Refer to the 3300 Customer Engineering manual for detailed m.ain- 
tenance information. 

Elapsed Time Meters 

Two elapsed time meters and a key-operated^ two-position switch are located 
on the control panel. Turning the key-operated Maintenance Mode switch to ON 
connects the Maintenance Time meter to the computer to record the amount of 
time the computer is used during a maintenance period. Removing the key con- 
nects the Operating Time meter to the computer to record norm.al operating 
time. Customers renting the computer are often billed according to the time 
recorded on this meter. The sum of the times recorded on both meters indi- 
cates the total computer running time. Only one of the two meters can operate 
at any one time. Either meter is active for a minimum of one second when a 
storage cycle occurs. 

Storage Protect Switches 

The 15 Storage protect switches are described in Section 2. 
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CONTROL DATA 3100, 3200, 3300 COMPUTER SYSTEMS 

CHARACTER SET AND 
BCD/ASCII CODE CONVERSIONS 



CONTROL DATA 3100, 3200, 3300 COMPUTER SYSTEMS 

CHARACTER SET 



INTERNAL 

BCD 

CODES 


EXTERNAL 

BCD 

CODES 


CONSOLE TYPEWRITER 

CHARACTERS (USES 
INTERNAL BCD ONLY) 


MAGNETIC 

TAPE UNIT 

CHARACTERS 


PUNCHED 
CARD 
CODES 


00 


12 


(zero) 


(zero) 





01 


01 


1 


1 


1 


02 


02 


2 


2 


2 


03 


03 


3 


3 


3 


04 


04 


4 


4 


4 


05 


05 


5 


5 


5 


06 


06 


6 


6 


6 


07 


07 


7 


7 


7 


10 


10 


8 


8 


8 


11 


11 


9 


9 


9 


12 


(illegal) 


± 





2,8 


13 


13 


= 


# 


3.8 


14 


14 


II 


@ 


4,8 


15 


15 







5,8 


16 


16 


; 





6,8 


17 


17 


■p 


(file mark) 


7,8 


20 


60 


+ 


& 


12 


21 


61 


A 


A 


12.1 


22 


62 


B 


B 


12,2 


23 


63 


C 


C 


12, 3 


24 


64 


D 


D 


12,4 


25 


65 


E 


E 


12, 5 


26 


66 


F 


F 


12,6 


27 


67 


G 


G 


12, 7 


30 


70 


H 


H 


12,8 


31 


;7i;. ■ 


I 


I 


12, 9 


32 


72: ' 


(Shift to 
lower case) 


+0 


12,0 


33 


73 


.(period) 


. 


12,3,8 


34 


74 


) 


n 


12,4,8 


35 


75 


'(apostrophe) 


— 


12,5,8 


36 


76 


@ 


— 


12,6,8 


37 


77-- . 


! 


— 


12,7,8 






A-1 


(Continued 


Dn next page) 
Rev. A 



INTERNAL 


EXTERNAL 


CONSOLE TYPEWRITER 


MAGNETIC 


PUNCHED 


BCD 


BDC 


CHARAC'l'ERS (USES 


TAPE UNIT 


CARD 


CODES 


CODES 


INTERNAL BCD ONLY) 


CHARACTERS 


CODES 


40 


40 


-(minus) 


-(minus) 


11 


41 


41 


J 


J 


11,1 


42 


42 


K 


K 


11.2 


43 


43 


L 


L 


11,3 


44 


44 


M 


M 


11,4 


45 


45 


N 


N 


11.5 


46 


46 


O 


O 


11,6 


47 


47 


P 


P 


11,7 


50 


50 


Q 


Q 


11,8 


51 


51 


R 


R 


11,9 


52 


52 


° (degree) 


-O 


11,0 


53 


53 


$ 


$ 


11.3,8 


54 


54 


* 


^ 


11,4,8 


55 


55 


# 





11,5,8 


56 


56 


% 





11,6,8 


57 


57 


(Shift to 
upper case) 





11,7.8 


60 


20 


(space) 


(blank) 


(blank) 


61 


21 


/ 


/ 


0,1 


62 


22 


S 


S 


0,2 


63 


23 


T 


T 


0,3 


64 


24 


U 


U 


0,4 


65 


25 


V 


V 


0,5 


66 


26 


w 


w 


0,6 


67 


27 


X 


X 


0.7 


70 


30 


Y 


Y 


0,8 


71 


31 


z 


z 


0,9 


72 


32 


& 


— 


0,2,8 


73 


33 


, (comma) 


, (comma) 


0,3,8 


74 


34 


( 


% 


0.4,8 


75 


35 


(tab) 





0,5,8 


76 


36 


(backspace) 





0,6,8 


77 


37 


(carriage return) 





0, 7,8 
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BCD/ASCII CONVERSION TABLE 



6 -BIT 
BCD CODE 


8 -BIT 

ASCII 

CHARACTER 


BINARY STATUS OF ASCII CHARACTER 
(BIT POSITIONS) 


7* 


6 


5 


4 


3 


2 


1 





00 



























01 


1 























02 


2 


















1 





03 


3 


















1 




04 


4 















1 








05 


5 















1 







06 


6 















1 


1 




07 


7 















1 


1 




10 


8 












1 










11 


9 












1 










12 


! 












1 





1 




13 


= 












1 


1 







14 


! 
















1 


1 




15 


& 
















1 


1 




16 


% 
















1 







17 


[ 





1 





1 


1 





1 




20 


+ 








1 





1 





1 




21 


A 
























22 


B 



















1 




23 


C 



















1 




24 


D 
















1 







25 


E 
















1 







26 


F 
















1 


1 




27 


G 
















1 


1 




30 


H 













1 










31 


I 













1 










32 


< 








1 


1 


1 


1 







33 


. 








1 





1 


1 


1 




34 


) 








1 





1 










35 


A 





1 





1 


1 


1 


1 





36 


II 








1 











1 




37 


; 








1 


1 


1 





1 





*ASCII bit 7 is unassigned and "O" for all codes. 
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BCD/ ASCII CONVERSION TABLE (Cont'd) 



6 -BIT 


8 -BIT 




BINARY STATUS OF ASCII CHARACTER 


BCD CODE 


ASCII 
CHARACTER 




(BIT POSITIONS) 




7* 


6 


5 


4 


3 


2 


1 





40 


- 








1 







1 





1 


41 


J 


















1 





42 


K 


















1 


1 


43 


L 















1 








44 


M 















1 





1 


45 


N 















1 


1 





46 


O 















1 


1 


1 


47 


P 










1 














50 


Q 










1 











1 


51 


R 










1 








1 





52 


! 








1 














1 


53 


$ 








1 








1 








54 


* 








1 





1 





1 





55 


# 








1 











1 


1 


56 


\ 





1 




















57 


> 








1 


1 


1 


1 


1 





60 


Blank 








1 

















61 


/ 








1 





1 


1 


1 


1 


62 


S 





1 





1 








1 


1 


63 


T 





1 





1 





1 








64 


U 





1 





1 





1 





1 


65 


V 





1 





1 





1 


1 





66 


W 





1 





1 





1 


1 


1 


67 


X 





1 





1 













70 


Y 





1 





1 










1 


71 


Z 





1 





1 







1 





72 


~\ 





1 





1 




1 





1 


73 


Comma 








1 







1 








74 


( 








1 
















75 


~ 





1 





1 




1 








76 







1 





1 




1 


1 


1 


77 


? 








1 


1 




1 


1 


1 



*ASCII bit 7 is unassigned and "O" for all codes. 
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SUPPLEMENTARY ARITHMETIC INFORMATION 



B, SUPPLEMENTARY ARITHMETIC INFORMATION 



NUMBER SYSTEMS 

Any number system may be defined by two characteristics, the radix or base 
and the modulus. The radix or base is the number of unique symbols used in 
the system. The decimal system has ten symbols, through 9. Modulus is 
the number of unique quantities or magnitudes a given system can distinguish. 
For example, an adding machine with ten digits, or counting wheels, would 
have a modulus of lOlO-l. The decimal system has no modulus because an 
infinite number of digits can be written, but the adding machine has a modulus 
because the highest number which can be expressed is 9, 999, 999, 999. 

Most number systems are positional; that is, the relative position of a symbol 
determines its magnitude. In the decimal system, a 5 in the units column 
represents a different quantity than a 5 in the tens column. Quantities equal 
to or greater than 1 may be represented by using the 10 symbols as coefficients 
of ascending powers of the base 10. The number 984io is: 

9 X 102 = 9 X 100 = 900 
+8 X lol = 8 X 10 = 80 



+4 X 10*^ = 4 X 1 = 4 

984 



10 



Quantities less than 1 may be represented by using the 10 symbols as co- 
efficients of ascending negative powers of the base 10. The number 0. 593io 
may be represented as: 

5 X 10"^ = 5 X . 1 = . 5 
+9 X 10-2 = 9 X .01 = . 09 
+3 X 10-3 = 3 X .001 = . 003 

0. 593;^Q 

Binary Number System 

Computers operate faster and more efficiently by using the binary number 
system. There are only two symbols, and 1; the base = 2. The following 
shows the positional value: 

... 2^ 2^ 2-^ 2^ 2^ 2° 

32168 4 2 1 Binary point 
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The binary number 110 10 represents: 



X 2^ = X 32 


= 


+1 X 2'^ = 1 X 16 


= 16 


+1 X 2^ = 1 X 8 


= 8 


+0 X 2^ = X 4 


= 


+1 X 2^ = 1 X 2 


= 2 


+0 X 2° = X 1 


= 




26io 



Fractional binary numbers may be represented by using the symbols as co- 
efficients of ascending negative powers of the base. 

2 ~^ 2 "^ 2 "^ 2 "'^ 2 "^ . . . 
Binary Point 1/2 1/4 1/8 1/16, 1/32 

The binary number 0. 10 110 may be represented as: 

1 X 2 "J = 1 X 1/2 =1/2 = 8/16 
+0x2 ^ = 0x1/4 =0 =0 

+1 X 2 ""^ = 1 X 1/8 = 1/8 = 2/16 
+1 x 2 ""^ = 1 X 1/16 = 1/16 = 1/16 

1171610 

Octal Number System 

The octal number system uses eight discrete symbols, through 7. With base 
eight the positional value is: 

. . . 8^ 84 8^ 82 sl 8° 

32,768 4,096 512 64 8 1 

The octal number SlSs represents: 

5 X 82 = 5 X 64 = 320 
+1 X sl = 1 X 8 = 8 
+3 X 8^ = 3 X 1 = 3 



33110 

Fractional octal numbers may be represented by using the symbols as co- 
efficients of ascending negative powers of the base. 

8 "1 8-2 8-3 Q-4^ ... 

1/8 1/64 1/512 1/4096 

The octal number 0. 4520 represents: 

4x8-1 = 4x1/8 = 256/512 
+5 X 8 -2 = 5 X 1/64 = 40/512 
+2x8 "^ = 2 X 1/512 = 2/512 

298/512 = 149/256io 
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ARITHMETIC 

Addition and Subtraction 

Binary numbers are added according to the following rules: 

0+0 = 
+ 1 = 1 
1+0=1 
1+1 = with a carry of 1 

The addition of two binary numbers proceeds as follows (the decimal equivalents 
verify the result): 

Augend 0111 (7) 

Addend + 0100 +(4) 

Partial Sum 0011 

Carry 1_ 



Sum 1011 (11) 

Subtraction may be performed as an addition: 

8 (minuend) 8 (minuend) 

-6 (subtrahend) or +4 (lO's complement of subtrahend) 
2 (difference) 2 (difference - omit carry) 

The second method shows subtraction performed by the "adding the complement" 
method. The omission of the carry in the illustration has the effect of reducing 
the result by 10. 

One's Complement: The computer performs all arithmetic and counting 
operations in the binary one's complement mode. In this system, positive 
numbers are represented by the binary equivalent and negative numbers in ones' 
complement notation. 

The one's complement representation of a number is found by subtracting each 
bit of the number from 1. For example: 

1111 
-1001 9 



0110 (one's complement of 9) 

This representation of a negative binary quantity may also be obtained by sub- 
stituting "I's" for "O's" and "O's" for "I's". 

The value zero can be represented in one's complement notation in two ways: 

0000 -^002 Positive (+) Zero 

1111 -*ll2 Negative (-) Zero 

The rules regarding the use of these two forms for computation are: 

. Both positive and negative zero are acceptable as arithmetic operands. 

• If the result of an arithmetic operation is zero, it will be expressed as 
positive zero. 
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One's complement notation applies not only to arithmetic operations performed 
in A, but also to the modification of execution addresses in the F register. 
During address modification, the modified address will equal 77777g only if the 
unmodified execution address equals IIIIIq and b = or (Bt>) = 11111^. 

Multiplic ati on 

Binary multiplication proceeds according to the following rules: 






X 





= 








X 


1 


= 





1 


X 





= 





1 


X 


1 


= 


1 



Multiplication is always performed on a bit-by-bit basis. Carries do not result 
from multiplication, since the product of any two bits is always a single bit. 



Decimal example: 



Multiplicand 
Multiplier 
Partial Products 

Product 



fi 



14 

28 

4 (shifted one place left) 
16810 



The shift of the second partial product is a shorthand method for writing the 
true value 140. 



Binary example: 



Multiplicand (14) 
Multiplier (12) 



Partial Products 



Product (168^q) 



1110 
1100 
0000 
0000 
1110 
1110 



shift to place 
digits in proper 
columns 



101010002 



The computer determines the running subtotal of the partial products. Rather 
than shifting the partial product to the left to position it correctly, the com- 
puter right shifts the summation of the partial products one place before the 
next addition is made. When the multiplier bit is "l", the multiplicand is 
added to the running total and the results are shifted to the right one place. 
When the multiplier bit is "O", the partial product subtotal is shifted to the 
right (in effect, the quantity has been multiplied by 102). 

Division 

The following examples shows the familiar method of decimal division: 
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Divisor 



13 



14 
185 

13 
55 
52 
3 



Quotient 
Dividend 

Partial Dividend 

Remainder 



The computer performs division in a similar manner (using binary equivalents): 



Divisor 



1101 



1110 


Quotient (14) 


llOlllOOl 


Dividend 


1101 




10100 




1101 




1110 


Partial Dividends 


1101 




11 


Remainder (3) 



However, instead of shifting the divisor right to position it for subtraction from 
the partial dividend (shown above), the computer shifts the partial dividend left, 
accomplishing the same purpose and permitting the arithmetic to be performed 
in the A register. The computer counts the number of shifts, which is the 
number of quotient digits to be obtained; after the correct number of counts, the 
routine is terminated. 



CONVERSIONS 

The procedures that may be used when converting from one number system to 
another are power addition, radix arithmetic, and substitution. 



TABLE B-1. RECOMMENDED CONVERSION PROCEDURES 
(INTEGER AND FRACTIONAL) 



Conversion 


Recommended Method 


Binary to Decimal 
Octal to Decimal 
Decimal to Binary 
Decimal to Octal 
Binary to Octal 
Octal to Binary 


Power Addition 
Power Addition 
Radix Arithmetic 
Radix Arithmetic 
Substitution 
Substitution 


GENERAL RULES 

r. > r„ : use Radix Arithmetic, Substitution 
r\ K r » : use Power Addition, Substitution 

r. = Radix of initial system 

rl = Radix of final system 
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Power Addition 

To convert a number from r^^ to rf (r j^ < Vf) write the number in its expanded r j^ 
polynomial form and simplify using rf arithmetic. 

EXAMPLE 1 Binary to Decimal (Integer) 

010 nip = 1(24) +0(2^) +1(2^) +l(2l) +1(20) 

= 1(16) +0(8) +1(4) +1(2) +1(1) 

= 16 +0 +4 +2 +1 

= 23jQ 

EXAMPLE 2 Binary to Decimal (Fractional) 

.0101„ = 0(2-1) +1(2-2) +0(2"^) +1(2"4) 
"^ = +1/4 +0 +1/16 

=5/16^0 

EXAMPLE 3 Octal to Decimal (Integer) 

324o = 3(8^) +2(8l) +4(8°) 
= 3(64) +2(8) +4(1) 
= 192 +16 +4 

= 212io 

EXAMPLE 4 Octal to Decimal (Fractional) 

.44o = 4(8-1) +4(8-2) 
° = 4/8 +4/64 
= 36/64io 
= 9/I610 



Radix Arithmetic 

To convert a whole number from r^ to rf (r^^ >rf): 
> Divide r^^ by rf using r^^ arithmetic 

. The remainder is the lowest order bit in the new expression 
. Divide the integral part from the previous operation by rf 
. The remainder is the next higher order bit in the new expression 

• The process continues until the division produces only a remainder 
which will be the highest order bit in the rf expression. 

To convert a fractional number from r^^ to r^: 
. Multiply r^ by rf using r^. arithmetic 

• The integral part is the highest order bit in the new expression 

• Multiply the fractional part from the previous operation by rf 

. The integral part is the next lower order bit in the new expression 

. The process continues until sufficient precision is achieved or the 
process terminates. 
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EXAMPLE 1 Decimal to Binary (Integer) 

45 -r 2 = 22 remainder 1; record 1 

22 -H 2 = 11 remainder 0; record 

11 -=-2=5 remainder 1; record 1 

5-^2=2 remainder 1; record 1 

2-^2=1 remainder 0; record 

1 -r 2 = remainder 1; record 1 

Thus: 45^Q = lOllOlg 101101 

EXAMPLE 2 Decimal to Binary (Fractional) 

. 25 X 2 = 0. 5; record 

.5 X 2 = 1. 0; record 1 

.0 X 2 = 0. 0; record 

Thus: . 25jQ = . OlOg .010 

EXAMPLE 3 Decimal to Octal (Integer) 
273 -^8 = 34 remainder 1; record 1 



34 



4 renaainder 2; record 2 



4 -rg = remainder 4; record 4_ 



Thus: 273^Q = 421g 421 

EXAMPLE 4 Decimal to Octal (Fractional) 

. 55 X 8 = 4. 4; record 4 
.4 X 8 = 3. 2; record 3 

.2 X 8 = 1. 6; record 1 



. 431 



Thus: . 55^Q = . 431. . .8 



Substitution 



This method permits easy conversion between octal and binary representations 
of a number. If a number in binary notation is partitioned into triplets to the 
right and left of the binary point, each triplet may be converted into an octal 
digit. Similarly, each octal digit may be converted into a triplet of binary digits. 

EXAMPLE 1 Binary to Octal 



Binary = 110 000 . 001 010 
Octal =60.1 2 




\MPLE 2 Octal to Binary 




Octal = 6 5 0.2 2 
Binary = 110 101 000 . 010 010 


7 
111 
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FIXED POINT ARITHMETIC 
24-Bit Precision 



Any number may be expressed in the form kB , where k is a coefficient, B a 
base number, and the exponent n the power to which the base number is raised. 

A fixed point number assumes: 

• The exponent n = for all fixed point numbers. 

• The coefficient, k, occupies the same bit positions within the computer 
word for all fixed point numbers. 

• The radix (binary) point remains fixed with respect to one end of the 
expression. 

A fixed point number consists of a sign bit and coefficient as shown below. The 
upper bit of any fixed point number designates the sign of the coefficient (23 
lower order bits). If the bit is "l", the quantity is negative since negative 
numbers are represented in one's complement notation; a "O" sign bit signifies 
a positive coefficient. 

23 22 00 



COEFFICIENT 



I 
SIGN BIT 

The radix (binary) point is assumed to be immediately to the right of the lowest 
order bit (00). 

In many instances, the values in a fixed point operation may be too large or too 
small to be expressed by the computer. The programmer must position the 
numbers within the word format so they can be represented with sufficient pre- 
cision. The process, called scaling, consists of shifting the values a pre- 
determined number of places. The numbers must be positioned far enough to 
the right in the register to prevent overflow but far enough to the left to main- 
tain precision. The scale factor (number of places shifted) is expressed as the 
power of the base. For example, 5, 100, OOO^^q may be expressed as 0. 51 x 
lO"^, 0.051 X 108, 0.0051 x 109, etc. The scale factors are 7, 8, and 9. 

Since only the coefficient is used by the computer, the programmer is res- 
ponsible for remembering the scale factors. Also, the possibility of an over- 
flow during intermediate operations must be considered. For example, if two 
fractions in fixed point format are multiplied, the result is a number < 1. If 
the same two fractions are added, subtracted, or divided, the result may be 
greater than one and an overflow will occur. Similarly, if two integers are 
multiplied, divided, subtracted or added, the likelihood of an overflow is 
apparent. 

48-Bit Precision (Double Precision) 

The 48 -bit Add, Subtract, Multiply and Divide instructions enable operands to 
be processed. The Multiply and Divide instructions utilize the E register and 
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therefore are executed as trapped instructions if the applicable arithmetic 
option is not present in a system. Figure 5-5 in the Instruction Section illus- 
trates the operand formats in 48 -bit precision Multiply and Divide instructions. 

FLOATING POINT ARITHMETIC 

As an alternative to fixed point operation a method involving a variable radix 
point, called floating point, is used. This significantly reduces the amount of 
bookkeeping required on the part of the programmer. 

By shifting the radix point and increasing or decreasing the value of the exponent, 
widely varying quantities which do not exceed the capacity of the machine may 
be handled. 

Floating point numbers within the computer are represented in a form similar 
to that used in scientific notation, that is, a coefficient orfraction multiplied 
by a number raised to a power. Since the computer uses only binary numbers, 
the numbers are multiplied by powers of two. 

F • 2 where: F = fraction 

E = exponent 

In floating point, different coefficients need not relate to the same power of the 
base as they do in fixed point format. Therefore, the construction of a floating 
point number includes not only the coefficient but also the exponent. 

NOTE 

Refer to Figure 5-6 in the Instruction Section for the operand format and 
bit functions for specific floating point instructions. 

Coefficient 

The coefficient consists of a 36-bit fraction in the 36 lower order positions of 
the floating point word. The coefficient is a normalized fraction; it is equal to 
or greater than 1/2 but less than 1. The highest order bit position (47) is 
occupied by the sign bit of the coefficient. If the sign bit is a "O", the co- 
efficient is positive; a "l" bit denotes a negative fraction (negative fractions are 
represented in one's complement notation). 

Exponent 

The floating point exponent is expressed as an 11-bit quantity with a value 
ranging from 0000 to 37778- It is formed by adding a true positive exponent 
and a bias of 20008 or a true negative exponent and a bias of 17778. This re- 
sults in a range of biased exponents as shown on the following page. 
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True Positive 
Exponent 


Biased 
Exponent 


True Negative 
Exponent 


Biased 
Exponent 


+0 
+1 
+2 

+1776 
+17778 


2000 
2001 
2002 

3776 
37778 


-0 
-1 
-2 

-1776 
-17778 


2000* 

1776 

1775 

0001 
OOOOs 



EXPONENT (INCLUDING BIAS) 



COEFFICIENT 



Zl 



•SIGN BIT 



*Minus zero is sensed as positive zero by the computer and is therefore 
biased by 20008 rather than 17778- 

The exponent is biased so that floating point operands can be compared with 
each other in the normal fixed point mode. 

As an example, compare the unbiased exponents of +528 ^"•'^ +0.028 (Example 1). 
EXAMPLE 1 

Number = +52g 
000 000 110 (36 bits) 

Coefficient Exponent Coefficient 

Sign 




Coefficient 
Sign 



Number = +0.02g 
1 1 111 111 Oil 
Exponent 



(3 6 bits) 
Coefficient 



In this case +0. 02 appears to be larger than +52 because of the larger exponent. 
If, however, both exponents are biased (Example 2), changing the sign of both 
exponents makes +52 greater than +0. 02. 



EXAMPLE 2 







Coefficient 
Sign 



Number = +528 
1 000 000 110 
Exponent 



(3 6 bits) 
Coefficient 





Coefficient 
Sign 



Number = +0.028 
1 111 111 Oil 
Exponent 



(36 bits) 
Coefficient 
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When bias is used with the exponent, floating point operation is more versatile 
since floating point operands can be compared with each other in the normal 
fixed point mode. 

All floating point operations involve the A, Q, and E registers, plus two con- 
secutive storage locations M and M + 1. The A and Q registers are treated as 
one 48-bit register. Indirect addressing and address modification are applicable 
to this whole group of instructions. 

Operand Formats 

The AQ register and the storage address contents have identical formats. 

In both cases the maximum possible shift is 64 (773) bit positions. Since the 
coefficient consists of only 36 bits at the start, any shift greater than 36 
positions will, of course, always result in an answer equal to the larger of the 
two original operands. 



(47) 
23 


(46) (36) 
22 12 


(35) (24) 
11 00 


(A) and (M) 






/ 

Sign of 


' , 'V V ' 

11 -bit operand Upper 12 bits of 



Coefficient exponent including operand coefficient 

bias 



23 00 

(Q) and (M + 1) 



■ y 

Lower 24 bits of opei'and coefficient 

Exponents 

The 3100, 3200, 3300 Computers use an 11 -bit exponent that is biased by 20003 
for floating point operations. The effective modulus of the exponent is + 17778 
or + 102310- 

Exponent Equalization 

During floating point addition and subtraction, the exponents involved are 
equalized prior to the operation. 

• Addition - The coefficient of the algebraically smaller exponent is 
automatically shifted right in AQE until the exponents are equal. A 
maximum of 778 shifts may occur. 



B-11 Rev. A 



• Subtraction - If AQ contains the algebraically smaller exponent, the 
coefficient in AQ is shifted right in AQE until the exponents are equal. 
If (M) and (M + 1) have the smaller exponent, the complement of the 
coefficient of (M) and (M + 1) is shifted right in AQE until the exponents 
are equal or until a maximum of 77o shifts are performed. 

Rounding 

Rounding is an automatic floating point operation and is particularly necessary 
when floating point arithmetic operations yield coefficient answers in excess 
of 3 6 bits. 

Although standard floating point format requires only a 3 6-bit coefficient, 
portions of the E register are used for extended coefficients. Refer to in- 
dividual instruction descriptions for E register applications. 

Rounding modifies the coefficient result of a floating point operation by adding 
or subtracting a "l" from the lowest bit position in Q without regard to the 
biased exponent. The coefficient of the answer in AQ passes through the adder 
with the rounding quantity before normalization. The conditions for rounding 
are classified according to arithmetic operation in Table B-2. 



TABLE B-2. ROUNDED CONDITIONS FOLLOWING ARITHMETIC OPERATION 



Arithmetic 
OPERATION 


Bit 23 of the 
A Register 


Bit 47 of the E Register 
or 
(Ratio of Residue /Divisor 
for Divide Only) 


Applicable 
Rounding 


ADD 
or 

SUBTRACT 


0* 





No 


0* 


1 


Add "1" 


1* 





Subtract "1" 


1* 


1 


No 


Comments: 'Rounding occurs as a result of inequality between 
the sign bits of AQ and E. 


MULTIPLY 








No 





1 


Add "1" 


1 





Subtract "1" 


1 


1 


No 


Comments: A floating point multiplication yields a 76 bit 

coefficient. Comparison between the sign bits of 
AQ and E indicates that the lower 3 6 bits are equal 
to or greater than 1/2 of the lowest order bit in AQ. 


DIVIDE 





> 1/2 (absolute) 


Add "1" 





< 1/2 (absolute) 


No 


1 


> 1/2 (absolute) 


Subtract "1" 


1 


< 1/2 (absolute) 


No 


Comments: Rounding occurs if the answer resulting from the 

final residue division is equal to or greater than 1/2. 



^Condition of bit 23 of the A register immediately after equalization, 
to Exponent Equalization on preceeding page). 



(Refer 
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Normalizing 

Normalizing brings the above answer back to a fraction with a value between 
one -half and one with the binary point to the left of the 36th bit of the coefficient. 
In other words, the final normalized coefficient in AQ will range in value from 
236 to 237-1 including sign. Arithmetic control normalizes the answer by right 
or left shifting the coefficient the necessary number of places and adjusting the 
exponent. It does not shift the residue that is in E. 

Faults 

Three conditions are considered faults during the execution of floating point 
instructions : 

• Exponent overflow (> + ITTIq) 

• Exponent underflow ( <— 1777g) 

• Division by zero, by too small a number, or by a number that is not 
in floating point format 

These faults have several things in common: 

• They can be sensed by the INS (77. 3) instruction 
■ Sensing automatically clears them 

• The program should sense for these faults only after the floating point 
instructions have had sufficient time to go to completion 

• They may be used to cause an interrupt 

FIXED POINT /FLOATING POINT CONVERSIONS 
Fixed Point To Floating Point 

• Express the number in binary. 

• Normalize the number. A normalized number has the most significant 

1 positioned immediately to the right of the binary point and is expressed 
in the range 1 / 2 < k < 1 . 

• Inspect the sign of the true exponent. If the sign is positive add 2000o 
(bias) to the true exponent of the normalized number. If the sign is 
negative, add the bias 17773 t° ^^e true exponent of the normalized 
number. In either case, the resulting exponent is the biased exponent. 

• Assemble the number in floating point. 

• Inspect the sign of the coefficient. If negative, complement the 
assembled floating point number to obtain the true floating point re- 
presentation of the number. If the sign of the coefficient is positive, 
the assembled floating point number is the true representation. 
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EXAMPLE 1 Convert +4. to floating point 

• The number is expressed in octal. 

• Normalize 4. = 4. x 8^ = 0. 100x2^ 

• Since the sign of the true exponent is positive, add 2OOO3 
(bias) to the true exponent. Biased exponent = 2000 + 3. 

• Assemble number in floating point format. 
Coefficient = 400 000 000 OOOg 

Biased Exponent = 200 3g 

Assembled word = 2003 400 000 000 OOOs 

• Since the sign of the coefficient is positive, the floating point 
representation of +4. is as shown. If, however, the sign of 
the coefficient were negative, it would be necessary to com- 
plement the entire floating point word. 

EXAMPLE 2 Convert -4. to floating point 

• The number is expressed in octal. 

. Normalize -4. = -4. x 8° = -0. 100 x 2^ 

• Since the sign of the true exponent is positive, add 2000g 
(bias) to the true exponent. Biased exponent = 2000 + 3. 

• Assemble number in floating point format. 
Coefficient = 400 000 000 OOOg 

Biased Exponent = 200 3g 

Assembled word = 2003 400 000 000 OOOg 

• Since the sign of the coefficient is negative, the assembled 

floating point word must be complemented. Therefore, the 

true floating point representation for 

-4.0 = 5774 377 777 777 777o. 

o 

EXAMPLE 3 Convert 0. 5^0 to floating point 

• Convert to octal 0. Sj^q = 0. 43 

. Normalize 0. 4 = 0. 4 x 8° = 0. 100 x 20 

• Since the sign of the true exponent is positive, add 2000g 
(bias) to the true exponent. Biased exponent = 2000 + 0. 

• Assemble number in floating point format. 
Coefficient = 400 000 000 OOOg 

Biased Exponent = 2000g 

Assembled word = 2000 400 000 000 OOOg 

• Since the sign of the coefficient is positive, the floating point 
representation of +0. 5-|^q is as shown. If, however, the sign 
of the coefficient were negative, it would be necessary to 
complement the entire floating point word. This example is a 
special case of floating point since the exponent of the nor- 
malized number isO and could be represented as -0. The 
exponent would then be biased by 1777g instead of 2000g because 
of the negative exponent. The 3100 and 3200, however, recognize 
-0 as +0 and bias the exponent by 2000g. 
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EXAMPLE 4 Convert 0. O43 to floating point 

• The number is expressed in octal. 

. Normalize 0. 04 = 0. 04 x 8° = 0. 4 x 8"^ = 0. 100 x 2"^. 

• Since the sign of the true exponent is negative, add l^^^g 
(bias) to the true exponent. Biased exponent = 17778 "*" 
(-3) = 1774g 

• Assemble number in floating point format. 
Coefficient = 400 000 000 OOO3 

Biased Exponent = 17748 

Assembled word = 1774 400 000 000 OOOg 

. Since the sign of the coefficient is positive, the floating 
point representation of 0. 04g is as shown. If, however, the 
sign of the coefficient were negative, it would be necessary 
to complement the entire floating point word. 

F loating Point to Fixed Point Format 

• If the floating point number is negative, complement the entire floating 
point word and record the fact that the quantity is negative. The ex- 
ponent is now in a true biased form. 

• If the biased exponent is equal to or greater than 2000g, subtract 2000g 
to obtain the true exponent; if less than 20008, subtract 17778 to obtain 
true exponent. 

• Separate the coefficient and exponent. If the true exponent is negative, 
the binary point should be moved to the left the number of bit positions 
indicated by the true exponent. If the true exponent is positive, the 
binary point should be moved to the right the number of bit positions 
indicated by the true exponent. 

• The coefficient has now been converted to fixed binary. The sign of the 
coefficient will be negative if the floating point number was complemented 
in step one. (The sign bit must be extended if the quantity is placed in a 
register. ) 

• Represent the fixed binary number in fixed octal notation. 

EXAMPLE 1 Convert floating point number 2003 400 000 000 OOOg 
to fixed octal 

. The floating point number is positive and remains uncomplemented. 

. The biased exponent > 20003; therefore, subtract 2000g from the 
biased exponent to obtain the true exponent of the number. 
2003 - 2000 = +3. 

. Coefficient = 400 000 000 OOOg = . IOO2. Move binary point 
to the right three places. Coefficient = 100. O2. 

• The sign of the coefficient is positive because the floating 
point number was not complemented in step one. 

• Represent in fixed octal notation. 
100. X 2O = 4.0 x 8°. 
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EXAMPLE 2 Convert floating point number 

5774 377 777 777 777^ to fixed octal 

o 

• The sign of the coefficient is negative; therefore, complement 
the floating point number. 

Complement = 2003 400 000 000 OOOg 

• The biased exponent (in complemented form) > 20008; there- 
fore, subtract 20008 f^o^"^ the biased exponent to obtain the 
true exponent of the number 2003 - 2000 = +3. 

. Coefficient = 4000 000 000 OOOg = 0. IOO2. Move binary 
point to the right three places. Coefficient = 100. O2. 

• The sign of the coefficient will be negative because the floating 
point number was originally complemented. 

• Convert to fixed octal. -100. Og = 4. Og. 

EXAMPLE 3 Convert floating point number 

1774 400 000 000 OOOg to fixed octal 

• The floating point number is positive and remains uncom- 
plemented. 

• The biased exponent < 20008; therefore, subtract 17778 
from the biased exponent to obtain the true exponent of the 
number. 1774g - 1777g = -3. 

. Coefficient = 400 000 000 OOOg = . lOOg. Move binary 
point to the left three places. Coefficient = . OOOIOO2. 

• The sign of the coefficient is positive because the floating 
point number was not complemented in step one. 

• Represent in fixed octal notation. 
.OOOIOO2 = .04g. 
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APPENDIX C 



PROGRAMMING REFERENCE TABLES AND 
CONVERSION INFORMATION 



TABLE OF POWERS OF TWO 
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n 




2- 

10 
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1 


0.5 














































4 


2 


0.25 
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3 


0.125 














































15 


4 


0.062 


5 












































32 


5 


031 


25 












































64 


6 


0.015 


625 












































128 


7 


0.007 


812 


5 










































256 


8 


0.003 


906 


25 










































512 


9 


0.001 


953 


125 








































1 


024 


10 


0.000 


976 


562 


5 






































2 


048 


11 


0.000 


488 


281 


25 






































4 


096 


12 


0.000 


244 


140 


625 






































8 


192 


13 


0.000 


122 


070 


312 


5 




































16 


384 


14 


0000 


061 


035 


156 


25 




































32 


768 


15 


0000 


030 


517 


578 


125 




































65 


536 


16 


0.000 


015 


258 


789 


062 


5 


































131 


072 


17 


0.000 


007 


629 


394 


531 


25 


































262 


144 


18 


0000 


003 


814 


697 


265 


625 


































524 


288 


19 


0.000 


001 


907 


348 


632 


812 


5 






























1 


048 


576 


20 


0000 


000 


953 


674 


316 


406 


25 






























2 


097 


152 


21 


0000 


000 


476 


837 


158 


203 


125 






























4 


194 


304 


22 


0000 


000 


238 


418 


579 


101 


562 


5 




























8 


388 


608 


23 


0000 


000 


119 


209 


289 


550 


781 


25 




























16 


777 


216 


24 


0.000 


000 


059 


604 


644 


775 


390 


625 




























33 


554 


432 


25 


000 


000 


029 


802 


322 


387 


695 


312 


5 


























67 


108 


864 


26 


0000 


000 


014 


901 


161 


193 


847 


656 


25 


























134 


217 


728 


27 


0000 


000 


007 


450 


580 


596 


923 


828 


125 


























268 


435 


456 


28 


0.000 


000 


003 


725 


290 


298 


461 


914 


062 


5 
























536 


870 


912 


29 


0000 


000 


001 


862 


645 


149 


230 


957 


031 


25 






















1 


073 


741 


824 


30 


0.000 


000 


000 


931 


322 


574 


615 


478 


515 


625 






















2 


147 


483 


648 


31 


0.000 


000 


000 


465 


661 


287 


307 


739 


257 


812 


5 




















4 


294 


967 


296 


32 


0.000 


000 


000 


232 


830 


643 


653 


869 


628 


906 


25 




















8 


589 


934 


592 


33 


0000 


000 


000 


116 


415 


321 


826 


934 


314 


453' 


125 




















17 


179 


869 


184 


34 


0000 


000 


000 


058 


207 


660 


913 


467 


407 


226 


562 


5 


















34 


359 


738 


368 


35 


0.000 


000 


000 


029 


103 


830 


456 


733 


703 


613 


281 


25 


















68 


719 


476 


736 


36 


0.000 


000 


000 


014 


551 


915 


228 


366 


351 


806 


640 


625 


















137 


438 


953 


472 


37 


0000 


000 


000 


007 


275 


957 


614 


183 


425 


903 


320 


312 


6 
















274 


877 


906 


944 


38 


0.000 


000 


000 


003 


637 


978 


807 


091 


712 


951 


660 


156 


25 
















549 


755 


813 


888 


39 


0.000 


000 


000 


001 


818 


989 


403 


545 


856 


475 


830 


073 


125 














1 


099 


511 


627 


776 


40 


0.000 


000 


000 


000 


909 


494 


701 


772 


928 


237 


915 


039 


062 


B 












2 


199 


023 


255 


552 


41 


0.000 


000 


000 


000 


454 


747 


350 


886 


464 


118 


957 


519 


531 


25 












4 


398 


046 


511 


104 


42 


0.000 


000 


000 


000 


227 


373 


675 


443 


232 


059 


473 


759 


765 


625 












8 


796 


093 


022 


208 


43 


0.000 


000 


000 


000 


113 


686 


837 


721 


616 


029 


739 


379 


382 


812 


5 










17 


592 


186 


044 


416 


44 


0.000 


000 


000 


000 


056 


843 


418 


860 


303 


014 


869 


639 


941 


406 


25 










35 


184 


372 


088 


832 


45 


0.000 


000 


000 


000 


028 


421 


709 


430 


404 


007 


434 


844 


970 


703 


125 










70 


368 


744 


177 


664 


46 


0.000 


000 


000 


000 


014 


210 


854 


715 


202 


003 


717 


422 


485 


351 


562 


5 








140 


737 


488 


355 


328 


47 


0.000 


000 


000 


000 


007 


105 


427 


357 


601 


001 


858 


711 


242 


675 


781 


25 








281 


474 


976 


710 


656 


48 


0.000 


000 


000 


000 


003 


552 


713 


678 


BOO 


500 


929 


355 


621 


337 


890 


625 








562 


949 


953 


421 


312 


49 


0.000 


000 


000 


000 


001 


776 


356 


839 


400 


250 


464 


677 


810 


663 


945 


312 


5 




1 


125 


899 


906 


842 


624 


50 


0.000 


000 


000 


000 


000 


888 


178 


419 


700 


125 


232 


333 


905 


334 


472 


656 


25 




2 


251 


799 


813 


685 


248 


51 


0.000 


000 


000 


000 


000 


444 


089 


209 


850 


062 


616 


169 


452 


667 


236 


323 


125 




4 


503 


599 


627 


370 


496 


52 


0.000 


000 


000 


000 


000 


222 


044 


604 


925 


031 


308 


034 


726 


333 


618 


164 


062 


5 


9 


007 


199 


254 


740 


992 


53 


0.000 


000 


000 


000 


000 


111 


022 


302 


462 


515 


654 


042 


363 


166 


809 


032 


031 


25 


18 


014 


398 


509 


481 


984 


54 


0.000 


000 


000 


000 


000 


055 


511 


151 


231 


257 


827 


021 


181 


533 


404 


541 


015 


625 


36 


028 


797 


018 


963 


968 


55 


0.000 


000 


000 


000 


000 


027 


755 


575 


615 


628 


913 


510 


590 


791 


702 


270 


507 


312 5 


72 


057 


594 


037 


927 


936 


56 


0.000 


000 


000 


000 


000 


013 


877 


787 


307 


814 


456 


755 


295 


395 


851 


135 


253 


906 25 


144 


115 


188 


075 


855 


872 


57 


0.000 


000 


000 


000 


000 


006 


938 


893 


903 


907 


223 


377 


647 


697 


925 


567 


626 


953 125 


288 


230 


376 


161 


711 


744 


68 


0.000 


000 


000 


000 


000 


003 


469 


446 


951 


953 


614 


133 


823 


348 


962 


783 


813 


476 562 5 


576 


460 


752 


303 


423 


488 


59 


0000 


000 


000 


000 


000 


001 


734 


723 


475 


976 


307 


094 


411 


924 


431 


391 


906 


733 231 26 


1 152 


921 


504 


606 


846 


976 


60 


0000 


000 


000 


000 


000 


000 


867 


361 


737 


988 


403 


547 


205 


962 


240 


695 


953 


369 140 625 



C-1 



Rev. A 



DECIMAL/BINARY POSITION TABLE 



Largest Decimal 
Integer 


Decimal 
Digits 
Reqd* 


Number 

of 
Binary 
Digits 


Largest Decimal Fraction 


1 
3 
7 
15 


1 


1 
2 
3 
4 


.5 
.75 
.876 
.937 5 


31 
63 
127 


2 


6 
6 
7 


.968 75 
.984 376 
.992 187 5 


266 

611 

1 023 


3 


8 
9 
10 


.996 093 75 
.998 046 876 
.999 023 437 5 


2 047 
4 096 
8 191 
16 383 


4 


11 
12 
13 
14 


.999 511 718 75 
.999 755 859 375 
.999 877 929 687 5 
.999 938 964 843 76 


32 767 
65 535 
131 071 


5 


15 
16 
17 


.999 969 482 421 875 
.999 984 741 210 937 5 
,999 992 370 606 468 76 


262 143 

524 287 

1 048 575 


6 


18 
19 
20 


.999 996 185 302 734. 375 
.999 998 092 651 367 187 5 
.999 999 046 325 683 593 76 


2 097 151 
4 194 303 
8 388 607 
16 777 216 


7 


21 
22 
23 
24 


.999 999 523 162 841 796 876 
.999 999 761 681 420 898 437 5 
.999 999 880 790 710 449 218 75 
.999 999 940 395 355 244 609 375 


33 654 431 
67 108 863 
134 217 727 


8 


25 
26 
27 


.999 999 970 197 677 612 304 687 5 
.999 999 985 098 838 806 152 343 75 
.999 999 992 549 419 403 076 171 875 


268 435 456 

536 870 911 

1 073 741 823 


9 


a 

29 
30 


.999 999 996 274 709 701 638 085 937 5 
.999 999 998 137 354 850 769 042 968 76 
.999 999 999 068 677 425 384 521 484 376 


2 147 483 647 
4 294 967 295 
8 689 934 591 
17 179 869 183 


10 


31 
32 
33 
34 


.999 999 999 534 338 712 692 260 742 187 5 
.999 999 999 767 169 366 346 130 371 093 75 
.999 999 999 883 584 678 173 065 185 546 876 
999 999 999 941 792 339 086 532 592 773 437 5 


34 359 738 367 
68 719 476 736 
137 438 953 471 


11 


35 
36 
37 


.999 999 999 970 896 169 643 266 296 386 718 75 
.999 999 999 985 448 034 771 633 148 193 359 375 
.999 999 999 992 724 042 386 816 574 096 679 687 6 


274 877 906 943 

549 755 813 887 

1 099 511 627 775 


12 


38 
39 
40 


.999 999 999 996 362 021 192 908 287 048 339 843 75 
.999 999 999 998 181 010 596 454 143 524 169 921 875 
.999 999 999 999 090 505 298 227 071 762 084 960 937 5 


2 199 023 255 551 
4 398 046 511 103 
8 796 093 022 207 
17 592 186 044 415 


13 


41 
42 
43 
44 


.999 999 999 999 645 252 649 113 535 881 042 480 468 75 
.999 999 999 999 772 626 324 556 767 940 521 240 234 375 
.999 999 999 999 886 313 162 278 383 970 260 620 117 187 5 
999 999 999 999 943 166 581 139 191 985 130 310 068 593 75 


36 184 372 088 831 
70 368 744 177 663 
140 737 488 356 327 


14 


45 
46 
47 


.999 999 999 999 971 578 290 669 595 992 565 155 029 296 875 
.999 999 999 999 985 789 146 284 797 996 282 677 514 648 437 5 
999 999 999 999 992 894 572 642 398 998 141 288 757 324 218 75 


281 474 976 710 655 

662 949 953 421 311 

1 126 899 90S 842 623 


16 


48 
49 
SO 


.999 999 999 999 996 447 286 321 199 499 070 644 378 662 109 376 
999 999 999 999 998 223 643 160 599 749 535 322 189 331 064 687 6 
.999 999 999 999 999 111 821 580 299 874 767 661 094 666 527 343 76 


2 251 799 813 685 247 
4 503 699 627 370 496 
9 007 199 264 740 991 
18 014 398 509 481 983 


16 


51 
52 
53 
54 


.999 999 999 999 999 565 910 790 149 937 383 830 547 332 763 671 875 
.999 999 999 999 999 777 955 395 074 968 691 915 273 666 381 835 937 6 
.999 999 999 999 999 888 977 697 537 484 345 967 636 833 190 917 968 75 
999 999 999 999 999 944 488 848 768 742 172 978 818 416 595 463 984 375 


36 028 797 01 B 963 967 
72 0S7 694 037 927 935 
144 115 188 075 855 871 


17 


55 
56 
57 


.999 999 999 999 999 972 244 424 384 371 086 489 409 208 297 729 492 187 5 
.999 999 999 999 999 986 122 212 192 185 543 244 704 604 148 864 746 093 75 
.999 999 999 999 999 993 061 106 096 092 771 622 352 302 074 432 373 046 875 


288 23D 376 151 711 743 

576 460 752 303 423 487 

1 152 921 504 606 846 975 


18 


68 
59 
60 


.999 999 999 999 999 996 530 563 048 046 385 811 176 151 037 216 186 523 437 5 
.999 999 999 999 999 998 265 276 524 023 192 905 588 075 518 608 093 261 718 75 
999 999 999 999 999 999 132 638 262 Oil 596 452 794 037 759 304 0^6 630 859 375 



•Larger numbers within a digit group should be checked for exact number of decimal digits required. 
Examples of use: 

1 . Q. What is the largest decimal value that can be expressed by 36 binary digits? 
A. 68,719,476,735. 

2. Q. How many decimal digits will be required to express a 22-bit number? 
A. 7 decimal digits. 
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OCTAL ARITHMETIC MATRICES 



ADDITION-SUBTRACTION 






1 


2 


3 


— TT- 

4 


5 


6 


7 


1 


2 


3 


4 


5 


6 




10 


2 


3 


4 


5 


6 


7 


10 


11 


3 


4 


5 


6 


7 


10 


11 


12 


4 


5 


6 


7 


10 


11 


12 


13 


5 


6 


7 


10 


11 


12 


13 


14 


6 


7 


10 


11 


12 


13 


14 


15 


7 
! 


10 


11 


12 


13 


14 


15 


16 



MULTIPLICATION-DIVISION 



i i 
1 2 1 3 


- \ 1 

4 j 5 ■ 6 ♦ 7 

' 1 


1 1 


2 




4 


5 


6 




2 2 

: 


4 


6 


10 


12 


14 


16 


3 


3 


6 


11 


14 


17 


22 


25 


■ 4 


4 


10 


14 


20 


24 


30 


34 


5 


5 


12 


17 


24 


31 


36 


43 


6 


6 


14 


22 


30 


36 


44 


52 


7 


7 


16 


25 


34 


43 


52 


61 
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CONSTANTS 






jr 





3.14159 


26535 


89793 


23846 26433 83279 50 


v/5 


= 


1.732 050 807 


569 




v/TO 


= 


3.162 277 660 


1683 




e 


= 


2.71828 


18284 


59045 


23536 


In 2 


= 


0.69314 


71805 


599453 




In 10 


= 


2.30258 


50929 


94045 


68402 


logio 2 


= 


0.30102 


99956 


63981 




logio e 


= 


0.43429 


44819 


03251 


82765 


log to logio 


e = 


9.63778 


43113 


00537 


-10 


logio w 


= 


0.49714 


98726 


94133 


85435 


1 degree 


= 


0.01745 


32925 


11943 


radians 


1 radian 


= 


57.29577 


95131 


degrees 




logio(5) 


= 


0.69897 


00043 


36019 




7! 


= 


5040 








81 


= 


40320 








91 


= 


362.880 








10! 


= 


3.628.800 








Ill 


= 


39.916.800 






12! 


= 


479.001,600 






13! 


= 


6.227,020.800 






14! 


= 


87.178.291.200 






15! 


= 


1.307.674.368.000 


1 




16! 


= 


20.922.7P9.888.000 




180 


= 


0.0174E 


i 3292E 


i 19943 


1 29576 92369 07684 9 


{If 


= 


2.4674 


01100 


27233 


96 


k^ 


= 


3.8757 


84585 


03747 


74 


{if 


= 


6.0880 


68189 


62515 


20 


klf 


= 


9.5631 


15149 


54004 


49 


{^ 


= 


15.0217 


06149 


61413 


07 


fl? 


= 


23.5960 


40842 


00618 


62 


fi)- 


= 


37.0645 


72481 


52567 


57 


ti)- 


= 


58.2208 


97135 


63712 


59 


(f)'° 


= 


91.4531 


71363 


36231 


53 


fl)' 


= 


143.6543 


05651 


31374 


95 


ff^" 


= 


225.6516 


55645 


350 




^" 


= 


354.4527 


91822 


91051 


47 


\ 2/ 


= 


556.7731 


43417 


624 
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CONSTANTS (Continued) 



ir2 


= 


9.86960 


44010 


89358 


61883 


43909 


9988 


27r2 


= 


19.73920 


88021 


78717 


23766 


87819 


9976 


37r2 


= 


29.60881 


32032 


68075 


85680 


31729 


9964 


4^2 


= 


39.47841 


76043 


57434 


47533 


75639 


9952 


5ir2 


= 


49.34802 


20054 


46793 


09417 


19549 


9940 


6x2 


= 


59.21762 


64065 


36151 


71300 


63459 


9928 


77r= 


= 


69,08723 


08076 


25510 


33184 


07369 


9916 


87r2 


= 


78.95683 


52087 


14868 


95067 


51279 


9904 


97r2 


= 


88.82643 


96098 


04227 


56950 


95189 


9892 



V2 


1 + V2 


(1 + V2P 


(1 + V^)" 


(1 + V2)^ 


(1 + v^)8 


(1 + V^)'° 


(1 + V2)'2 


(1 + V2.y* 


(1 + Viv^ 


(1 + >/2)'8 



1.414 213 562 373 095 048 801 688 

2.414 213 562 373 095 048 801 688 

5.828 427 124 746 18 

33.970 562 748 477 08 

197.994 949 366 116 30 

1153.999 133 448 220 72 

6725.999 851 323 208 02 

39201.999 974 491 027 40 

228485.999 995 622 956 38 

1331713.999 999 246 711 

7761797.999 999 884 751 



Sin 


.5 


Cos 


.5 


Tan 


.5 


Sin 




Cos 




Tan 




Sin 


1.5 


Cos 


1.5 


Tan 


1.5 



0.47942 55386 04203 

0.87758 25618 90373 

0.54630 24898 43790 

0.84147 09848 07896 

0.54030 23058 68140 

1.55740 77246 5490 

0.99749 49866 04054 

0.07073 72016 67708 

14.10141 99471 707 
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OCTAL-DECIMAL INTEGER CONVERSION TABLE 








1 


2 


3 


4 


5 


6 


7 


0000 


0000 


0001 


0002 


O0O3 


0004 


0005 


0006 


0007 


0010 


0008 


0009 


0O10 


0011 


0012 


0013 


0014 


0015 


0020 


0016 


0O17 


0018 


0019 


0020 


0021 


0022 


0023 


0030 


0024 


0026 


0026 


0027 


0028 


0029 


0030 


0031 


0040 


0032 


11033 


0034 


0035 


0036 


0037 


0038 


0039 


0050 


0040 


0041 


0042 


0043 


0044 


0045 


0046 


0047 


0060 


0048 


0049 


0050 


0051 


0052 


0063 


0054 


0055 


0070 


0056 


0057 


0058 


0059 


0060 


0061 


0062 


0063 


0100 


0064 


0065 


0066 


0067 


0068 


0069 


0070 


0071 


0110 


0072 


0073 


0074 


0075 


0076 


0077 


0078 


0079 


0120 


0080 


0081 


0082 


0083 


0084 


0085 


0086 


0087 


0130 


0088 


0089 


0090 


0091 


0092 


0093 


0094 


0095 


0140 


0096 


0097 


0098 


0099 


0100 


0101 


0102 


0103 


01S0 


0104 


0105 


0106 


0107 


0108 


0109 


0110 


0111 


0160 


0112 


0113 


0114 


0115 


0116 


0117 


0118 


0119 


0170 


0120 


0121 


0122 


0123 


0124 


012& 


0126 


0127 


0200 


0128 


0129 


0130 


0131 


0132 


0133 


0134 


0135 


0210 


0136 


0137 


0138 


0139 


0140 


0141 


0142 


0143 


0220 


0144 


0145 


0146 


0147 


0148 


0149 


0150 


0151 


0230 


0152 


0153 


0164 


0155 


016,6 


0157 


0158 


0159 


0240 


0160 


0161 


0162 


0163 


0164 


0165 


0166 


0167 


0250 


0168 


0169 


0170 


0171 


0172 


0173 


0174 


0175 


0260 


0176 


0177 


0178 


0179 


0180 


0181 


0182 


0183 


0270 


0184 


0185 


0186 


0187 


0188 


0139 


0190 


0191 


0300 


0192 


0193 


0194 


0195 


0196 


0197 


0198 


0199 


0310 


0200 


0201 


0202 


0203 


0204 


0205 


0206 


0207 


0320 


0208 


02O9 


0210 


0211 


0212 


0213 


0214 


0215 


0330 


0216 


0217 


0218 


0219 


0220 


0221 


0222 


0223 


0340 


0224 


0225 


0226 


0227 


0228 


0229 


0230 


0231 


0350 


0232 


0233 


0234 


0235 


0236 


0237 


0238 


0239 


0360 


0240 


0241 


0242 


0243 


0244 


0245 


0246 


0247 


0370 


0248 


0249 


0250 


0251 


0252 


0253 


0254 


0255 








1 


2 


3 


4 


5 


6 


7 


0400 


0256 


0257 


0258 


0259 


0260 


0261 


0262 


0263 


0410 


0264 


0265 


0266 


0267 


0268 


0269 


0270 


0271 


0420 


0272 


0273 


0274 


0275 


0276 


0277 


0278 


0279 


0430 


0280 


0281 


0282 


0283 


0284 


0285 


0286 


0287 


0440 


0238 


0289 


0290 


0291 


0292 


0293 


0294 


0295 


0450 


0296 


0297 


0298 


0299 


0300 


0301 


0302 


0303 


0460 


0304 


0306 


0306 


0307 


0308 


0309 


0310 


0311 


0470 


0312 


0313 


0314 


0315 


0316 


0317 


0318 


0319 


0500 


0320 


0321 


0322 


0323 


0324 


0325 


0326 


0327 


0610 


0328 


0329 


0330 


0331 


0332 


0333 


0334 


0335 


0520 


0336 


0337 


0338 


0339 


0340 


0341 


0342 


0343 


0530 


0344 


0345 


0346 


0347 


0348 


0349 


0360 


0361 


0540 


0352 


0353 


0354 


0355 


0356 


0357 


0358 


0359 


0550 


0360 


0361 


0362 


0363 


0364 


0365 


0366 


0367 


0560 


0368 


0369 


0370 


0371 


0372 


0373 


0374 


0375 


0570 


0376 


0377 


0378 


0379 


0380 


0381 


0382 


0383 


0600 


0384 


0385 


0386 


0387 


0388 


0389 


0390 


0391 


0610 


0392 


0393 


0394 


0395 


0396 


0397 


0398 


0399 


0620 


0400 


0401 


0402 


0403 


0404 


0405 


0406 


0407 


0630 


0408 


0409 


0410 


0411 


0412 


0413 


0414 


0415 


0640 


0416 


0417 


0418 


0419 


0420 


0421 


0422 


0423 


0650 


0424 


0425 


0426 


0427 


0428 


0429 


0430 


0431 


0660 


0432 


0433 


0434 


0436 


0436 


0437 


0438 


0439 


0670 


0440 


0441 


0442 


0443 


0444 


0445 


0446 


0447 


0700 


0448 


0449 


0450 


0451 


0452 


0453 


0454 


0455 


0710 


0456 


0457 


0458 


0459 


0460 


0461 


0462 


0463 


0720 


0464 


0465 


0466 


0467 


0468 


0469 


0470 


0471 


0730 


0472 


0473 


0474 


0475 


0476 


0477 


0478 


0479 


0740 


0480 


0481 


0482 


0483 


0484 


0485 


0486 


0487 


0750 


0488 


0489 


0490 


0491 


0492 


0493 


0494 


0495 


0760 


0496 


0497 


0498 


0499 


0500 


0601 


0502 


0503 


0770 


0504 


0505 


0506 


0507 


0508 


0509 


0510 


0511 



0777 
lOctall 



Octal 
10000 
20000 
30000 
40000 
50000 - 
60000 - 
70000 ■ 



0511 
(Decimal) 



Decimal 

4096 

8192 
12288 
16384 
20480 
24576 
28672 








1 


2 


3 


4 


5 


6 


7 


1000 


0512 


0613 


0514 


0616 


0516 


0617 


0618 


0519 


1010 


0620 


0521 


0522 


0523 


0524 


0525 


0526 


0627 


1020 


0678 


0529 


0530 


0531 


0532 


0533 


0534 


0635 


1030 


0536 


0537 


0538 


0539 


0540 


0541 


0542 


0643 


1040 


0644 


0545 


0546 


0547 


0548 


0549 


0550 


0551 


1050 


0552 


0653 


0564 


0555 


0656 


0557 


0558 


0559 


1060 


0560 


0561 


0562 


0563 


0564 


0566 


0566 


0667 


1070 


0568 


0569 


0570 


0571 


0672 


0573 


0574 


0576 


1100 


0576 


0577 


0678 


0679 


0580 


0581 


0582 


0583 


1110 


0684 


0585 


0586 


0587 


0588 


0589 


0590 


0691 


1120 


0692 


0593 


0594 


0596 


0596 


0697 


0598 


0599 


1130 


0600 


0601 


0602 


0603 


0604 


0605 


0606 


0607 


1140 


0608 


0609 


0610 


0611 


0612 


0613 


0614 


0615 


1150 


0616 


0617 


0618 


0619 


0620 


0621 


0622 


0623 


1160 


0624 


0626 


0626 


0627 


0628 


0629 


0630 


0631 


1170 


0632 


0633 


0634 


0635 


0636 


0637 


0638 


0639 


1200 


0640 


0641 


0642 


0643 


0644 


0646 


0646 


0647 


1210 


0648 


0649 


0650 


0651 


0652 


0653 


0664 


0655 


1220 


0666 


0657 


0658 


0659 


0660 


0661 


0662 


0663 


1230 


0664 


0665 


0666 


0667 


0668 


0669 


0670 


0671 


1240 


0672 


0673 


0674 


0675 


0676 


0677 


0678 


0679 


1250 


0680 


0681 


0682 


0683 


0684 


0635 


0686 


0687 


1260 


0688 


0689 


0690 


0691 


0692 


0693 


0694 


0695 


1270 


0696 


0697 


0698 


0599 


0700 


0701 


0702 


0703 


1300 


0704 


0705 


0706 


0707 


0708 


0709 


0710 


0711 


1310 


0712 


0713 


0714 


0715 


0716 


0717 


0718 


0719 


1320 


0720 


0721 


0722 


0723 


0724 


0725 


0/26 


0727 


1330 


0728 


0729 


0730 


0731 


0732 


0733 


0734 


0735 


1340 


0736 


0737 


0738 


0739 


0740 


0741 


0742 


0743 


1350 


0744 


0745 


0746 


0747 


0748 


0749 


0750 


0751 


1360 


0762 


0763 


0754 


0766 


0756 


0757 


0758 


0759 


1370 


0760 


0761 


0762 


0763 


0764 


0765 


0766 


0767 








1 


2 


3 


4 


5 


6 


7 


1400 


0768 


0769 


0770 


0771 


0772 


0773 


0774 


0776 


1410 


0776 


0777 


0778 


0779 


0780 


0781 


0782 


0783 


1420 


0784 


0785 


0786 


0787 


0788 


0789 


0790 


0791 


1430 


0792 


0793 


0794 


0795 


0796 


0797 


0798 


0799 


1440 


0800 


0801 


0802 


0803 


0804 


0805 


0806 


0807 


1460 


0808 


0809 


0810 


0811 


0812 


0813 


0814 


0816 


1460 


0816 


0817 


0818 


0819 


0820 


0321 


0822 


0823 


1470 


0824 


0826 


0826 


0827 


0828 


0829 


0830 


0831 


1500 


0832 


0833 


0834 


0835 


0836 


0837 


0838 


0839 


1610 


0840 


0841 


0842 


0843 


0844 


0845 


0846 


0847 


1520 


0848 


0849 


0860 


0851 


0852 


0863 


0854 


0865 


1530 


0856 


0857 


0858 


0869 


0860 


0861 


0862 


0863 


1640 


0864 


0866 


0866 


0867 


0868 


0869 


0870 


0871 


1550 


0872 


0873 


0874 


0876 


0876 


0877 


0878 


0879 


1560 


0880 


0881 


0882 


0883 


0884 


0385 


0886 


0837 


1570 


0888 


0889 


0890 


0891 


0892 


0893 


0894 


0895 


1600 


0896 


0897 


0898 


0899 


0900 


0901 


0902 


0903 


1610 


0904 


0906 


0906 


0907 


0903 


0909 


0910 


0911 


1620 


0312 


0913 


0914 


0915 


0916 


0917 


0918 


0919 


1630 


0920 


0921 


0922 


0923 


0924 


0925 


0926 


0927 


1640 


0928 


0929 


0930 


0931 


0932 


0933 


0934 


0935 


1650 


0936 


0937 


0938 


0939 


0940 


0941 


0942 


0943 


1660 


0944 


0945 


0946 


0947 


0948 


0949 


0950 


0951 


1670 


0962 


0953 


0954 


0955 


0956 


0957 


0968 


0969 


1700 


0960 


0961 


0962 


0963 


0964 


0965 


0966 


0967 


1710 


0968 


0969 


0970 


0971 


0972 


0973 


0974 


0975 


1720 


0976 


0977 


0978 


0979 


0980 


0981 


0982 


0933 


1730 


0984 


0985 


0986 


0987 


0988 


0989 


0990 


0991 


1740 


0992 


0993 


0994 


0995 


0996 


0997 


0998 


0999 


1760 


1000 


1001 


1002 


1003 


1004 


1005 


1006 


1007 


1760 


1008 


1009 


1010 


1011 


1012 


1013 


1014 


1015 


1770 


1016 


1017 


1018 


1019 


1020 


1021 


1022 


1023 



1000 



1777 
lOctal) 



1023 
(Decimatl 



Rev. A 



C-6 



OCTAL-DECIMAL INTEGER CONVERSION TABLE (Cont'd) 



2000 1024 













































1 


2 


3 


4 


6 


6 


7 







1 


2 


3 


4 


5 


6 


7 




2000 


1024 


1026 


1026 


1027 


1028 


1029 


1030 


1031 




2400 


1280 


1281 


1282 


1283 


1284 


1285 


1286 


1287 


to to 


2010 


1032 


1033 


1034 


1036 


1036 


1037 


1038 


1039 




2410 


1288 


1289 


1290 


1291 


1292 


1293 


1294 


1295 




2777 1635 


2020 


1040 


1041 


1042 


1043 


1044 


1045 


1046 


1047 




2420 


1296 


1297 


1298 


1299 


1300 


1301 


1302 


1303 




lOctal) (Decimal) 


2030 


1048 


1049 


1050 


1061 


1052 


1053 


1064 


1065 




2430 


1304 


1305 


1306 


1307 


1308 


1309 


1310 


1311 






2040 


1056 


1067 


1058 


1059 


1060 


1061 


1062 


1063 




2440 


1312 


1313 


1314 


1316 


1316 


1317 


1318 


1319 






2050 


1064 


1065 


1066 


1067 


1068 


1069 


1070 


1071 




2450 


1320 


1321 


1322 


1323 


1324 


1326 


1326 


1327 




Octal Decimal 
10000- 4096 


2060 


1072 


1073 


1074 


1076 


1076 


1077 


1078 


1079 




2460 


1328 


1329 


1330 


1331 


1332 


1333 


1334 


1336 




2070 


1080 


1081 


1082 


1083 


1084 


1086 


1086 


1087 




2470 


1336 


1337 


1338 


1339 


1340 


1341 


1342 


1343 




20000- 8192 


2100 


1088 


1089 


1090 


1091 


1092 


1093 


1094 


1095 




2500 


1344 


1345 


1346 


1347 


1348 


1349 


1350 


1351 




30000- 12288 


2110 


1096 


1097 


1098 


1099 


1100 


1101 


1102 


1103 




2610 


1352 


1353 


1354 


1366 


1356 


1357 


1358 


1369 




40000- 16384 


2120 


1104 


1105 


1106 


1107 


1108 


1109 


1110 


1111 




2520 


1360 


1361 


1362 


1363 


1364 


1365 


1366 


1367 




50000 - 20480 


2130 


1112 


1113 


1114 


1115 


1116 


1117 


1118 


1119 




2530 


1368 


1369 


1370 


1371 


1372 


1373 


1374 


1376 




60000 - 24576 


2140 


1120 


1121 


1122 


1123 


1124 


1126 


1126 


1127 




2640 


1376 


1377 


1378 


1379 


1380 


1381 


1382 


1383 




70000 - 28672 


2160 


1128 


1129 


1130 


1131 


1132 


1133 


1134 


1135 




2650 


1384 


1385 


1386 


1387 


1388 


1389 


1390 


1391 




2160 


1136 


1137 


1138 


1139 


1140 


1141 


1142 


1143 




2560 


1392 


1393 


1394 


1395 


1396 


1397 


1398 


1399 






2170 


1144 


1146 


1146 


1147 


1148 


1149 


1160 


1161 




2570 


1400 


1401 


1402 


1403 


1404 


1405 


1406 


1407 






2200 


1152 


1153 


1154 


1166 


1156 


1157 


1158 


1169 




2600 


1408 


1409 


1410 


1411 


1412 


1413 


1414 


1416 






2210 


1160 


1161 


1162 


1163 


1164 


1166 


1166 


1167 




2610 


1416 


1417 


1418 


1419 


1420 


1421 


1422 


1423 






2220 


1168 


1169 


1170 


1171 


1172 


1173 


1174 


1175 




2620 


1424 


1426 


1426 


1427 


1428 


1429 


1430 /M31 






2230 


1176 


1177 


1178 


1179 


1180 


1181 


1182 


1183 




2630 


1432 


1433 


1434 


1436 


1436 


1437 


1438 


1439 






2240 


1184 


1186 


1186 


1187 


1188 


1189 


1190 


1191 




2640 


1440 


1441 


1442 


1443 


1444 


1446 


1446 


1447 






2250 


1192 


1193 


1194 


1195 


1196 


1197 


1198 


1199 




2650 


1448 


1449 


1450 


1461 


1452 


1453 


1464 


1465 






2260 


1200 


1201 


1202 


1203 


1204 


1206 


1206 


1207 




2660 


1466 


1467 


1458 


1459 


1460 


1461 


1462 


1463 






2270 


1208 


1209 


1210 


1211 


1212 


1213 


1214 


1216 




2670 


1464 


1465 


1466 


1467 


1468 


1469 


1470 


1471 






2300 


1216 


1217 


1218 


1219 


1220 


1221 


1222 


1223 




2700 


1472 


1473 


1474 


1475 


1476 


1477 


1478 


1479 






2310 


1224 


1226 


1226 


1227 


1228 


1229 


1230 


1231 




2710 


1480 


1481 


1482 


1483 


1484 


1485 


1486 


1487 






2320 


1232 


1233 


1234 


1235 


1236 


1237 


1238 


1239 




2720 


1488 


1489 


1490 


1491 


1492 


1493 


1494 


1496 






2330 


1240 


1241 


1242 


1243 


1244 


1245 


1246 


1247 




2730 


1496 


1497 


1498 


1499 


1500 


1501 


1602 


1503 






2340 


1248 


1249 


1250 


1251 


1252 


1253 


1254 


1255 




2740 


1504 


1605 


1506 


1507 


1608 


1519 


1510 


1611 






2350 


1256 


1257 


1258 


1269 


1260 


1261 


1262 


1263 




2760 


1512 


1613 


1514 


1616 


1616 


1517 


1618 


1519 






2360 


1264 


1266 


1266 


1267 


1268 


1269 


1270 


1271 




2760 


1520 


1621 


1522 


1523 


1524 


1625 


1526 


1527 






2370 


1272 


1273 


1274 


1276 


1276 


1277 


1278 


1279 




2770 


1528 


1629 


1630 


1531 


1532 


1533 


1534 


1535 




3000 1536 







1 


2 


3 


4 


5 


6 


7 









1 


2 


3 


4 


5 


6 


7 




3000 


1536 


1637 


1638 


1639 


1640 


1641 


1642 


1543 




3400 


1792 


1793 


1794 


1795 


1796 


1797 


1798 


1799 


to to 


3010 


1544 


1546 


1546 


1647 


1648 


1549 


1550 


1561 




3410 


1800 


1801 


1802 


1803 


1804 


1806 


1806 


1807 




3777 2047 


3020 


1562 


1553 


1554 


1555 


1566 


1557 


1568 


1569 




3420 


1808 


1809 


1810 


1811 


1812 


1813 


1814 


1316 




(Detail (Decimal) 


3D30 


1560 


1561 


1562 


1563 


1564 


1566 


1666 


1567 




3430 


1816 


1817 


1818 


1819 


1820 


1821 


1822 


1323 






3040 


1568 


1569 


1570 


1571 


1572 


1573 


1574 


1575 




3440 


1824 


1826 


1826 


1827 


1828 


1829 


1830 


1831 






3060 


1576 


1577 


1578 


1579 


1580 


1581 


1682 


1683 




3460 


1832 


1833 


1834 


1835 


1836 


1837 


1838 


1839 






3060 


1584 


1685 


1686 


1687 


1588 


1689 


1690 


1591 




3460 


1840 


1841 


1842 


1843 


1844 


1846 


1846 


1847 






3070 


1592 


1693 


1694 


1695 


1698 


1697 


1598 


1599 




3470 


1848 


1849 


1850 


1351 


1852 


1863 


1864 


1855 






3100 


1800 


1601 


1602 


1603 


1604 


1605 


1606 


1607 




3600 


1856 


1867 


1858 


1859 


1860 


1861 


1862 


1863 






3110 


1608 


1609 


1610 


1611 


1612 


1613 


1614 


1616 




3510 


1864 


1865 


1866 


1867 


1868 


1869 


1870 


1871 






3120 


1616 


1617 


1618 


1619 


1620 


1621 


1622 


1623 




3520 


1872 


1873 


1874 


1875 


1876 


1877 


1878 


1879 






3130 


1524 


1625 


1626 


1627 


1628 


1629 


1630 


1631 




3530 


1880 


1881 


1882 


1883 


1884 


1885 


1886 


1837 






3140 


1632 


1633 


1634 


1635 


1636 


1637 


1638 


1639 




3540 


1888 


1889 


1890 


1891 


1892 


1893 


1894 


1895 






3150 


1640 


1641 


1642 


1643 


1644 


1646 


1646 


1647 




3550 


1896 


1897 


1898 


1899 


1900 


1901 


1902 


1903 






3160 


1648 


1649 


1650 


1651 


1652 


1653 


1654 


1665 




3560 


1904 


1906 


1906 


1907 


1908 


1909 


1910 


1911 






3170 


1656 


1667 


1658 


1659 


1660 


1661 


1662 


1663 




3570 


1912 


1913 


1914 


1915 


1916 


1917 


1918 


1919 






3200 


1664 


1665 


1666 


1667 


1668 


1669 


1670 


1671 




3600 


1920 


1921 


1922 


1923 


1924 


1925 


1926 


1927 






3210 


1672 


1673 


1674 


1676 


1676 


1677 


1678 


1679 




3610 


1928 


1929 


1930 


1931 


1932 


1933 


1934 


1936 






3220 


1680 


1681 


1682 


1683 


1684 


1685 


1686 


1687 




3620 


1936 


1937 


1938 


1939 


1940 


1941 


1942 


1943 






3230 


1688 


1689 


1690 


1691 


1692 


1693 


1694 


1695 




3630 


1944 


1946 


1346 


1947 


1948 


1949 


1950 


1951 






3240 


1696 


1697 


1698 


1699 


1700 


1701 


1702 


1703 




3640 


1952 


1963 


1964 


1955 


1956 


1957 


1953 


1959 






3250 


1704 


1706 


1706 


1707 


1708 


1709 


1710 


1711 




3650 


1960 


1961 


1962 


1963 


1964 


1965 


1966 


1967 






3260 


1712 


1713 


1714 


1716 


1716 


1717 


1718 


1719 




3660 


1968 


1969 


1970 


1971 


1972 


1973 


1974 


1976 






3270 


1720 


1721 


1722 


1723 


1724 


1726 


1726 


1727 




3670 


1976 


1977 


1978 


1979 


1980 


1981 


1932 


1983 






3300 


1728 


1729 


1730 


1731 


1732 


1733 


1734 


1735 




3700 


1984 


1985 


1986 


1987 


1988 


1989 


1990 


1991 






3310 


1736 


1737 


1738 


1739 


1740 


1741 


1742 


1743 




3710 


1992 


1993 


1994 


1995 


1996 


1997 


1998 


1999 






3320 


1744 


1745 


1746 


1747 


1748 


1749 


1750 


1751 




3720 


2000 


2001 


2002 


2003 


2004 


2005 


2006 


2007 






3330 


1752 


1753 


1754 


1756 


1756 


1757 


1758 


1769 




3730 


2008 


2009 


2010 


2011 


2012 


2013 


2014 


2015 






3340 


1760 


1761 


1762 


1763 


1764 


1766 


1766 


1767 




3740 


2016 


2017 


2018 


2019 


2020 


2021 


2022 


2023 






3360 


1768 


1769 


1770 


1771 


1772 


1773 


1774 


1775 




3760 


2024 


2026 


2026 


2027 


2028 


2029 


2030 


2031 






3360 


1776 


1777 


1778 


1779 


1780 


1781 


1782 


1783 




3760 


2032 


2033 


2034 


2035 


2036 


2037 


2038 


2039 






3370 


1784 


1786 


1786 


1787 


1786 


1789 


1790 


1791 




3770 


2040 


2041 


2042 


2043 


2044 


2045 


2046 


2047 













































C-7 



Rev, B 



OCTAL-DECIMAL INTEGER CONVERSION TABLE (Cont'd) 











































4000 2048 









1 


2 


3 


4 


5 


6 


7 







1 


2 


3 


4 


5 


6 


7 




4000 


2048 


2043 


2050 


2051 


2052 


2063 


2054 


2056 




4400 


2304 


2305 


2306 


2307 


2308 


2303 


2310 


2311 




4010 


2056 


2067 


2068 


2059 


2060 


2061 


2062 


2063 




4410 


2312 


2313 


2314 


2316 


2316 


2317 


2318 


2319 


to to 
4777 2559 




4020 


2064 


2066 


2066 


2067 


2068 


2069 


2070 


2071 




4420 


2320 


2321 


2322 


2323 


2324 


2325 


2326 


2327 




4030 


2072 


2073 


2074 


2075 


2076 


2077 


2078 


2079 




4430 


2328 


2329 


2330 


2331 


2332 


2333 


2334 


2336 




4040 


2080 


2081 


2082 


2083 


2084 


2086 


2086 


2087 




4440 


2336 


2337 


2338 


2333 


2340 


2341 


2342 


2343 


lOctall IDecimal) 




4050 


2088 


2089 


2090 


2091 


2092 


2093 


2094 


2095 




4460 


2344 


2346 


2346 


2347 


2348 


2343 


2350 


2361 






4060 


2096 


2097 


2098 


2099 


2100 


2101 


2102 


2103 




4460 


2362 


2363 


2354 


2366 


2366 


2367 


2368 


2369 






4070 


2104 


2105 


2106 


2107 


2108 


2109 


2110 


2111 




4470 


2360 


2361 


2362 


2363 


2364 


2366 


2366 


2367 


Octal Decimal 




4100 


2112 


2113 


2114 


2115 


2116 


2117 


2118 


2119 




4500 


2368 


2369 


2370 


2371 


2372 


2373 


2374 


2376 


10000- 4096 
20000- 8192 




4110 


2120 


2121 


2122 


2123 


2124 


2126 


2126 


2127 




4510 


2376 


2377 


2378 


2379 


2380 


2381 


2382 


2383 




4120 


2128 


2129 


2130 


2131 


2132 


2133 


2134 


2135 




4620 


2384 


2386 


2386 


2387 


2388 


2389 


2390 


2391 


30000 - 12288 




4130 


2136 


2137 


2138 


2139 


2140 


2141 


2142 


2143 




4530 


2392 


2393 


2394 


2395 


2396 


2397 


2338 


2339 


40000- 16384 




4140 


2144 


2145 


2146 


2147 


2148 


2149 


2150 


2161 




4640 


2400 


2401 


2402 


2403 


2404 


2405 


2406 


2407 


60000 - 20480 




4150 


2152 


2153 


2164 


2166 


2166 


2157 


2168 


2169 




4550 


2408 


2409 


2410 


2411 


2412 


2413 


2414 


2415 


60000 - 24676 




4160 


2160 


2161 


2162 


2163 


2164 


2166 


2166 


2167 




4660 


2416 


2417 


2418 


2419 


2420 


2421 


2422 


2423 


70000 - 28672 




4170 


2168 


2169 


2170 


2171 


2172 


2173 


2174 


2175 




4570 


2424 


2426 


2426 


2427 


2428 


2429 


2430 


2431 






4200 


2176 


2177 


2178 


2179 


2180 


2181 


2182 


2183 




4600 


2432 


2433 


2434 


2436 


2436 


2437 


2438 


2433 






4210 


2184 


2185 


2186 


2187 


2188 


2189 


2190 


2191 




4610 


2440 


2441 


2442 


2443 


2444 


2446 


2446 


2447 






4220 


2192 


2193 


2194 


2195 


2196 


2197 


2198 


2199 




4620 


2448 


2449 


2450 


2461 


2462 


2453 


2454 


2456 






4230 


2200 


2201 


2202 


2203 


2204 


2205 


2206 


2207 




4630 


2456 


2457 


2468 


2459 


2460 


2461 


2462 


2463 






4240 


2208 


2209 


2210 


2211 


2212 


2213 


2214 


2216 




4640 


2464 


2465 


2466 


2467 


2468 


2469 


2470 


2471 






4260 


2216 


2217 


2218 


2219 


2220 


2221 


2222 


2223 




4650 


2472 


2473 


2474 


2475 


2476 


2477 


2478 


2479 






4260 


2224 


2225 


2226 


2227 


2228 


2229 


2230 


2231 




4660 


2480 


2481 


2482 


2483 


2484 


2486 


2486 


2487 






4270 


2232 


2233 


2234 


2236 


2236 


2237 


2238 


2239 




4670 


2488 


2483 


2490 


2491 


2492 


2493 


2494 


2495 






4300 


2240 


2241 


2242 


2243 


2244 


2245 


2246 


2247 




4700 


2496 


2437 


2498 


2499 


2500 


2601 


2502 


2503 






4310 


2248 


2249 


2250 


2261 


2252 


2263 


2254 


2266 




4710 


2604 


2506 


2506 


2607 


2508 


2609 


2510 


2611 






4320 


2266 


2267 


2258 


2269 


2260 


2261 


2262 


2263 




4720 


2612 


2613 


2514 


2615 


2516 


2617 


2618 


2519 






4330 


2264 


2266 


2266 


2267 


2268 


2269 


2270 


2271 




4730 


2620 


2521 


2622 


2523 


2524 


2525 


2526 


2627 






4340 


2272 


2273 


2274 


2276 


2276 


2277 


2278 


2279 




4740 


2528 


2629 


2630 


2531 


2632 


2533 


2534 


2535 






4350 


2280 


2281 


2282 


2283 


2284 


2285 


2286 


2;,i7 




4760 


2536 


2637 


2638 


2539 


2540 


2641 


2542 


2543 






4360 


2288 


2289 


2290 


2291 


2292 


2293 


2294 


2296 




4760 


2644 


2646 


2646 


2547 


2648 


2549 


2550 


2661 






4370 


2296 


2297 


2298 


2299 


2300 


2301 


2302 


2303 




4770 


2662 


2653 


2664 


2656 


2666 


2557 


2668 


2653 











1 


2 


3 


4 


5 


6 


7 









1 


2 


3 


4 


5 


6 


7 


6000 2660 




5000 


2560 


2661 


2562 


2663 


2564 


2565 


2666 


2667 




5400 


2816 


2817 


2818 


2819 


2820 


2821 


2822 


2823 




5010 


2668 


2569 


2570 


2571 


2572 


2573 


2674 


2675 




5410 


2824 


2826 


2826 


2827 


2828 


2829 


2830 


2831 






6020 


2676 


2577 


2678 


2579 


2680 


2681 


2682 


2583 




6420 


2832 


2833 


2834 


2835 


2836 


2837 


2338 


2839 


to to 




5030 


2684 


2585 


2686 


2687 


2588 


2689 


2590 


2591 




6430 


2840 


2841 


2842 


2843 


2844 


2845 


2846 


2847 


6777 3071 




5040 


2592 


2693 


2694 


2595 


2596 


2697 


2598 


2599 




5440 


2848 


2849 


2850 


2861 


2862 


2853 


2864 


2855 


(Octall IDecimal) 




5050 


2600 


2601 


2602 


2603 


2604 


2605 


2606 


2607 




5460 


2866 


2857 


2858 


2869 


2860 


2861 


2862 


2863 






6060 


2608 


2609 


2610 


2611 


2612 


2613 


2614 


2616 




5460 


2864 


2865 


2866 


2867 


2868 


2863 


2870 


2871 






5070 


2616 


2617 


2618 


2619 


2620 


2621 


2622 


2623 




6470 


2872 


2873 


2874 


2876 


2876 


2877 


2878 


2879 






6100 


2624 


2625 


2626 


2627 


2628 


2629 


2630 


2631 




5500 


2880 


2881 


2882 


2883 


2884 


2886 


2386 


2887 






6110 


2632 


2633 


2634 


2636 


2636 


2637 


2638 


2639 




5610 


2888 


2889 


2890 


2891 


2892 


2893 


2894 


2836 






5120 


2640 


2641 


2642 


2643 


2644 


2646 


2646 


2647 




6620 


2896 


2897 


2898 


2899 


2900 


2301 


2902 


2903 






5130 


2648 


2649 


2660 


2651 


2662 


2663 


2654 


2665 




5630 


2904 


2905 


2306 


2907 


2908 


2309 


2910 


2911 






6140 


2656 


2657 


2668 


2669 


2660 


2661 


2662 


2663 




5540 


2912 


2913 


2914 


2916 


2916 


2917 


2918 


2919 






6150 


2664 


2665 


2666 


2667 


2668 


2669 


2670 


2671 




5550 


2920 


2921 


2922 


2923 


2924 


2926 


2926 


2327 






6160 


2672 


2673 


2674 


2676 


2676 


2677 


2678 


2679 




6560 


2928 


2929 


2930 


2931 


2932 


2933 


2334 


2936 






5170 


2680 


2681 


2682 


2683 


2684 


2686 


2686 


2687 




5670 


2936 


2937 


2938 


2333 


2940 


2941 


2942 


2343 






5200 


2688 


2689 


2690 


2691 


2692 


2693 


2694 


2695 




6600 


2944 


2946 


2946 


2347 


2948 


2949 


2350 


2951 






5210 


2696 


2697 


2698 


2699 


2700 


2701 


2702 


2703 




6610 


2962 


2953 


2954 


2366 


2956 


2957 


2958 


2363 






5220 


2704 


2706 


2706 


2707 


2708 


2709 


2710 


2711 




5620 


2960 


2961 


2962 


2363 


2964 


2965 


2966 


2367 






6230 


2712 


2713 


2714 


2715 


2716 


2717 


2718 


2719 




6630 


2968 


2969 


2970 


2971 


2972 


2973 


2974 


2975 






6240 


2720 


2721 


2722 


2723 


2724 


2726 


2726 


2727 




5640 


2976 


2977 


2978 


2973 


2380 


2981 


2982 


2983 






6250 


2728 


2729 


2730 


2731 


2732 


2733 


2734 


2736 




6650 


2984 


2986 


2986 


2387 


2388 


2389 


2990 


2391 






5260 


2736 


2737 


2738 


2739 


2740 


2741 


2742 


2743 




6660 


2992 


2993 


2994 


2396 


2336 


2937 


2938 


2939 






6270 


2744 


2745 


2746 


2747 


2748 


2749 


2760 


2751 




5670 


3000 


3001 


3002 


3003 


3004 


3006 


3006 


3007 






5300 


2762 


2763 


2754 


2765 


2766 


2757 


2758 


2759 




5700 


3008 


3009 


3010 


3011 


3012 


3013 


3014 


3016 






6310 


2760 


2761 


2762 


2763 


2764 


2765 


2766 


2767 




6710 


3016 


3017 


3018 


3019 


3020 


3021 


3022 


3023 






6320 


2768 


2769 


2770 


2771 


2772 


2773 


2774 


2775 




6720 


3024 


3026 


3026 


3027 


3028 


3023 


3030 


3031 






5330 


2776 


2777 


2778 


2779 


2780 


2781 


2782 


2783 




6730' 


3032 


3033 


3034 


3036 


3036 


3037 


3038 


3039 






5340 


2784 


2785 


2786 


2787 


2788 


2789 


2790 


2791 




6740 


3040 


3041 


3042 


3043 


3044 


3046 


3046 


3047 






5350 


2792 


2793 


2794 


2796 


2796 


2797 


2798 


2799 




5750 


3048 


3043 


3060 


3051 


3052 


3063 


3064 


3066 






5360 


2800 


2801 


2802 


2803 


2804 


2805 


2806 


2807 




6760 


3066 


3067 


3068 


3059 


3060 


3061 


3062 


3063 






5370 


2808 


2809 


2810 


2811 


2812 


2813 


2814 


2815 




5770 


3064 


3065 


3066 


3067 


3068 


3063 


3070 


3071 











































Rev. A 



C-8 



OCTAL-DECIMAL INTEGER CONVERSION TABLE (Cont'd) 



6000 3072 













































1 


2 


3 


4 


5 


6 


7 







1 


2 


3 


4 


5 


6 


7 




6000 


3072 


3073 


3074 


3075 


3076 


3077 


3078 


3079 




6400 


3328 


3329 


3330 


3331 


3332 


3333 


3334 


3335 


10 to 


601 


3080 


3081 


3082 


3083 


3084 


3085 


3086 


3087 




6410 


3336 


3337 


3338 


3339 


3340 


3341 


3342 


3343 




6777 3583 
(Octal) (Oecimal) 


6020 


3088 


3089 


3090 


3091 


3092 


3093 


3094 


3095 




6420 


3344 


3345 


3346 


3347 


3348 


3349 


3350 


3351 




6O30 


3096 


3097 


3098 


3099 


3100 


3101 


3102 


3103 




6430 


3352 


3353 


3354 


3355 


3356 


3357 


3358 


3359 




6040 


3104 


3105 


3106 


3107 


3108 


3109 


3110 


3111 




6440 


3360 


3361 


3362 


3363 


3364 


3365 


3366 


3367 






6050 


3112 


3113 


3H4 


3115 


3116 


3117 


3118 


3119 




6450 


3368 


3369 


3370 


3371 


3372 


3373 


3374 


3375 






6060 


3120 


3121 


3122 


3123 


3124 


3125 


3126 


3127 




6460 


3376 


3377 


3378 


3379 


3380 


3381 


3382 


3383 




Octal Decimal 


6070 


3128 


3129 


3130 


3131 


3132 


3133 


3134 


3135 




6470 


3384 


3385 


3386 


3387 


3388 


3389 


3390 


3391 




10000- 4096 










































20000- 8192 


6100 


3136 


3137 


3138 


3139 


3140 


3141 


3142 


3143 




6500 


3392 


3393 


3394 


3395 


3396 


3397 


3398 


3399 




30000- 12288 
40000 - 16384 
50000 - 20480 


6110 


3144 


3145 


3146 


3147 


3148 


3149 


3150 


3151 




6510 


3400 


3401 


3402 


3403 


3404 


3405 


3406 


3407 




6120 


3152 


3153 


3154 


3155 


3156 


3157 


3158 


3159 




6520 


3408 


3409 


3410 


3411 


3412 


3413 


3414 


3415 




6130 


3160 


3161 


3162 


3163 


3164 


3165 


3166 


3167 




6530 


3416 


3417 


3418 


3419 


3420 


3421 


3422 


3423 




6140 


3168 


3169 


3170 


3171 


3172 


3173 


3174 


3175 




6540 


3424 


3425 


3426 


3427 


3428 


3429 


3430 


3431 




60000 - 24576 


6150 


3176 


3177 


3178 


3179 


3180 


3181 


3182 


3183 




6550 


3432 


3433 


3434 


3435 


3436 


3437 


3438 


3439 




70000 - 28672 


6160 


3184 


3185 


3186 


3187 


3188 


3189 


3190 


3191 




6560 


3440 


3441 


3442 


3443 


3444 


3445 


3446 


3447 






6170 


3192 


3193 


3194 


3196 


3196 


3197 


3198 


3199 




6570 


3448 


3449 


3450 


3451 


3462 


3453 


3454 


3456 






6200 


3200 


3201 


3202 


3203 


3204 


3205 


3206 


3207 




6600 


3456 


3457 


3458 


3459 


3460 


3461 


3462 


3463 






6210 


3208 


3209 


3210 


3211 


3212 


3213 


3214 


3215 




6610 


3464 


3465 


3466 


3467 


3468 


3469 


3470 


3471 






6220 


3216 


3217 


3218 


3219 


3220 


3221 


3222 


3223 




6620 


3472 


3473 


3474 


3475 


3476 


3477 


3478 


3479 






6230 


3224 


3225 


3226 


3227 


3228 


3229 


3230 


3231 




6630 


3480 


3481 


3482 


3483 


3484 


3485 


3486 


3487 






6240 


3232 


3233 


3234 


3235 


3236 


3237 


3238 


3239 




6640 


3488 


3489 


3490 


3491 


3492 


3493 


3494 


3495 






6250 


3240 


3241 


3242 


3243 


3244 


3245 


3246 


3247 




6650 


3496 


3497 


3498 


3499 


3500 


3501 


3502 


3503 






6260 


3248 


3249 


3250 


3251 


3252 


3253 


3254 


3255 




6660 


3504 


3505 


3606 


3607 


3508 


3509 


3510 


3511 






6270 


3256 


3257 


3258 


3259 


3260 


3261 


3262 


3263 




6670 


3512 


3513 


3514 


3515 


3516 


3517 


3518 


3519 






6300 


3264 


3265 


3266 


3267 


3268 


3269 


3270 


3271 




6700 


3520 


3521 


3522 


3523 


3524 


3525 


3526 


3527 






6310 


3272 


3273 


3274 


3275 


3276 


3277 


3278 


3279 




6710 


3528 


3529 


3530 


3531 


3532 


3533 


3534 


3535 






6320 


3280 


3281 


3282 


3283 


3284 


3285 


3286 


3287 




6720 


3536 


3537 


3538 


3539 


3540 


3541 


3542 


3543 






6330 


3288 


3289 


3290 


3291 


3292 


3293 


3294 


3295 




6730 


3544 


3545 


3546 


3547 


3548 


3549 


3550 


3551 






6340 


3296 


3297 


3298 


3299 


3300 


3301 


3302 


3303 




6740 


3552 


3553 


3554 


3655 


3556 


3557 


3558 


3559 






6350 


3304 


3305 


3306 


3307 


3308 


3309 


3310 


3311 




6750 


3560 


3561 


3562 


3563 


3564 


3565 


3566 


3567 






6360 


3312 


3313 


3314 


3315 


3316 


3317 


3318 


3319 




6760 


3568 


3569 


3570 


3571 


3572 


3573 


3574 


3575 






6370 


3320 


3321 


3322 


3323 


3324 


3325 


3326 


3327 




6770 


3576 


3577 


3578 


3579 


3580 


3581 


3582 


3583 




7000 3584 







1 


2 


3 


4 


5 


6 


7 









1 


2 


3 


4 


5 


6 


7 




7000 


3584 


3585 


3586 


3587 


3588 


3589 


3590 


3591 




7400 


3840 


3841 


3842 


3843 


3844 


3845 


3846 


3847 


to to 


7010 


3592 


3593 


3594 


3595 


3596 


3597 


3598 


3599 




7410 


3848 


3849 


3850 


3851 


3852 


3853 


3854 


3855 




7777 4095 


7020 


3600 


3601 


3602 


3603 


3604 


3605 


3606 


3607 




7420 


3856 


3857 


3858 


3859 


3860 


3861 


3862 


3863 




lOctall (Decimall 


7030 


3608 


3609 


3610 


3611 


3612 


3613 


3614 


3615 




7430 


3864 


3865 


3866 


3867 


3868 


3869 


3870 


3871 




7040 


3010 


3617 


3618 


3619 


3620 


3621 


3622 


3623 




7440 


3872 


3873 


3874 


3875 


3876 


3877 


3878 


3879 






7050 


3624 


3625 


3626 


3627 


3628 


3629 


3630 


3631 




7450 


3880 


3881 


3882 


3883 


3884 


3885 


3886 


3887 






7060 


3632 


3633 


3634 


3635 


3636 


3637 


3638 


3639 




7460 


3888 


3889 


3890 


3891 


3892 


3893 


3894 


3895 






7070 


3640 


3641 


3642 


3643 


3644 


3645 


3646 


3647 




7470 


3896 


3897 


3898 


3899 


3900 


3901 


3902 


3903 






7100 


3648 


3649 


3650 


3651 


3652 


3653 


3654 


3655 




7S00 


3904 


3905 


3906 


3907 


3908 


3909 


3910 


3911 






7110 


3656 


3657 


3658 


3659 


3660 


3661 


3662 


3663 




7510 


3912 


3913 


3914 


3915 


3916 


3917 


3918 


3919 






7120 


3664 


3665 


3666 


3667 


3668 


3669 


3670 


3671 




7520 


3920 


3921 


3922 


3923 


3924 


3925 


3926 


3927 






7130 


3672 


3673 


3674 


3675 


3676 


3677 


3678 


3679 




7530 


3928 


3929 


3930 


3931 


3932 


3933 


3934 


3935 






7140 


3680 


3681 


3682 


3683 


3684 


3685 


3686 


3687 




7540 


3936 


3937 


3938 


3939 


3940 


3941 


3942 


3943 






7150 


3688 


3689 


3690 


3691 


3692 


3693 


3694 


3695 




7550 


3944 


3945 


3946 


3947 


3948 


3949 


3950 


3951 






7160 


3696 


3697 


3698 


3699 


3700 


3701 


3702 


3703 




7560 


3952 


3953 


3954 


3955 


3956 


3957 


3958 


3959 






7170 


3704 


3705 


3706 


3707 


3708 


3709 


3710 


3711 




7570 


3960 


3961 


3962 


3963 


3964 


3965 


3966 


3967 






7200 


3712 


3713 


3714 


3/15 


3716 


3717 


3718 


3719 




7600 


3968 


3969 


3970 


3971 


3972 


3973 


3974 


3975 






7210 


3720 


3721 


3722 


3723 


3724 


3725 


3726 


3727 




7610 


3976 


3977 


3978 


3979 


3980 


3981 


3982 


3983 






7220 


3728 


3729 


3730 


3731 


3732 


3733 


3734 


3735 




7620 


3984 


3985 


3986 


3987 


3988 


3989 


3990 


3991 






7230 


3736 


3737 


3738 


3739 


3740 


3741 


3742 


3743 




7630 


3992 


3993 


3994 


3995 


3996 


3997 


3998 


3999 






7240 


3744 


3745 


3746 


3747 


3748 


3749 


3750 


3751 




7640 


4000 


4001 


4002 


4003 


4004 


4005 


4006 


4007 






7250 


3752 


3753 


3754 


3755 


3756 


3757 


3758 


3759 




7650 


4008 


4009 


4010 


4011 


4012 


4013 


4014 


4015 






7260 


3760 


3761 


3762 


3763 


3764 


3765 


3766 


3767 




7660 


4016 


4017 


4018 


4019 


4020 


4021 


4022 


4023 






7270 


3768 


3769 


3770 


3771 


3772 


3773 


3774 


3775 




7670 


4024 


4025 


4026 


4027 


4028 


4029 


4030 


4031 






7300 


3776 


3777 


3778 


3779 


3780 


3781 


3782 


3783 




7700 


4032 


4033 


4034 


4035 


4036 


4037 


4038 


4039 






7310 


3784 


3785 


3786 


3787 


3788 


3789 


3790 


3791 




7710 


4040 


4041 


4042 


4043 


4044 


4045 


4046 


4047 






7320 


3792 


3793 


3794 


3795 


3796 


3797 


3798 


3799 




7720 


4048 


4049 


4050 


4051 


4052 


4053 


4054 


4055 






7330 


3800 


3801 


3802 


3803 


3804 


3805 


3806 


3807 




7730 


4056 


4057 


4058 


4059 


4060 


4061 


4062 


4063 






7340 


3808 


3809 


3810 


3811 


3812 


3813 


3814 


3815 




7740 


4064 


4065 


4066 


4067 


4068 


4069 


4070 


4071 






7350 


3816 


3817 


3818 


3819 


3820 


3821 


3822 


3823 




7750 


4072 


4073 


4074 


4075 


4076 


4077 


4078 


4079 






7360 


3824 


3825 


3826 


3827 


3828 


3829 


3830 


3831 




7760 


4080 


4081 


4082 


4083 


4084 


4085 


4086 


4087 






7370 


3832 


3833 


3834 


3835 


3836 


3837 


3838 


3839 




7770 


4088 


4089 


4090 


4091 


4092 


4093 


4094 


4095 













































C-9 



Rev. P 



OCTAL-DECIMAL FRACTION CONVERSION TABLE 



OCTAL 


DEC. 


OCTAL 


DEC. 


OCTAL 


DEC, 


OCTAL 


DEC. 


.000 


000000 


.100 


125000 


200 


2 50000 


300 


375000 


,001 


001953 


.101 


126953 


201 


251953 


301 


376953 


.002 


.003906 


102 


128906 


202 


253906 


.302 


378906 


.003 


.005859 


103 


130859 


.203 


255859 


303 


,380859 


.004 


.007812 


.104 


132812 


.204 


,257812 


304 


.382812 


.005 


,009765 


.105 


134765 


.205 


259765 


305 


384765 


.006 


01 1718 


.106 


136718 


206 


261718 


306 


.386718 


.007 


.013671 


107 


138671 


207 


263671 


307 


388671 


.010 


.015625 


110 


140625 


.210 


.265625 


310 


390625 


.01 1 


.017578 


.11 1 


142578 


.211 


.267578 


311 


392578 


.012 


.019531 


112 


144531 


212 


269531 


312 


394531 


.013 


.021484 


1 13 


146484 


.213 


.271484 


313 


.396484 


014 


.023437 


114 


148437 


.214 


273437 


314 


.398437 


,015 


.025390 


.115 


150390 


.215 


275390 


315 


.400390 


.016 


.027343 


.116 


152343 


.216 


.277343 


316 


402343 


.017 


.029296 


.117 


154296 


217 


.279296 


.317 


404296 


.020 


.031250 


.120 


156250 


220 


.281250 


.320 


406250 


021 


.033203 


.121 


158203 


221 


.283203 


321 


408203 


.022 


.035156 


.122 


160156 


222 


285156 


.322 


.410156 


.023 


.037109 


.123 


162109 


.223 


.287109 


.323 


.412109 


.024 


.039062 


.124 


164062 


224 


289062 


.324 


.414062 


.025 


.041015 


.125 


166015 


.225 


291015 


.325 


.416015 


.026 


.042968 


.126 


167968 


.226 


.292968 


326 


.417968 


.027 


.044921 


.127 


169921 


.227 


.294921 


327 


.419921 


.030 


.046875 


.130 


171875 


,230 


296875 


.330 


.421875 


,031 


048828 


.131 


173828 


.231 


.298828 


.331 


423828 


.032 


,050781 


.132 


175781 


.232 


.300781 


.332 


.425781 


,033 


.052734 


.133 


177734 


.233 


.302734 


.333 


.427734 


.034 


.054687 


.134 


179687 


.234 


.304687 


.334 


.429687 


.035 


.056640 


.135 


181640 


.235 


306640 


335 


.431640 


.036 


.058593 


.136 


183593 


.236 


.308593 


.336 


.433593 


.037 


.060546 


.137 


186546 


.237 


.310546 


.337 


.435546 


.040 


,062500 


.140 


187500 


.240 


.312500 


.340 


.437500 


.041 


.064453 


.141 


189453 


.241 


.314453 


.341 


.439453 


.042 


.066406 


.142 


191406 


.242 


.316406 


.342 


.441406 


.043 


.068359 


.143 


193359 


.243 


.318359 


343 


.443359 


.044 


.070312 


.144 


195312 


.244 


.320312 


344 


.445312 


.045 


,072265 


.145 


197265 


.245 


.322265 


345 


.447265 


046 


.074218 


.146 


199218 


.246 


.324218 


346 


.449218 


.047 


,076171 


.147 


201171 


.247 


,326171 


347 


.451171 


.050 


.078125 


.150 


203125 


.250 


.328125 


350 


.463125 


.051 


.080078 


.151 


205078 


.251 


.330078 


351 


.465078 


052 


.082031 


.152 


207031 


.252 


.332031 


352 


.457031 


.053 


.083984 


.153 


208984 


253 


.333984 


.353 


.468984 


- .054 


.085937 


.154 


210937 


.254 


.335937 


.354 


.460937 


.055 


.087890 


.155 


212890 


.255 


.337890 


355 


.462890 


.056 


.089843 


,156 


214843 


.256 


339843 


.356 


,464843 


,057 


.091796 


.157 


216796 


.257 


.341796 


.357 


.466796 


060 


.093750 


.160 


218750 


260 


.343750 


.360 


.468750 


.061 


.095703 


.161 


220703 


.261 


.345703 


- .361 


.470703 


.062 


.097656 


.162 


222656 


.262 


.347656 


.362 


.472656 


.063 


099609 


.163 


224609 


263 


.349609 


363 


474609 


.064 


.101562 


,164 


226562 


.264 


.351562 


.364 


.476562 


.065 


.103515 


,165 


228515 


.265 


.353515 


.365 


.478515 


066 


.105468 


.166 


230468 


.266 


.355468 


.366 


.480468 


.067 


.107421 


.167 


232421 


.267 


357421 


367 


.482421 


.070 


.109375 


,170 


234375 


.270 


.359375 


370 


.484375 


.071 


.111328 


.171 


236328 


271 


.361328 


371 


.486328 


.072 


,113281 


.172 


238281 


.272 


363281 


.372 


.488281 


.073 


.1 15234 


.173 


240234 


.273 


.365234 


.373 


,490234 


.074 


.117187 


.174 


242187 


274 


.367187 


.374 


,492187 


.075 


.119140 


.175 


244140 


275 


.369140 


.375 


.494140 


,076 


.121093 


,176 


246093 


.276 


.371093 


.376 


.496093 


,077 


.123046 


.177 


248046 


.277 


.373046 


.377 


.498046 



Rev. A 



C-10 



OCTAL-DECIMAL FRACTION CONVERSION TABLE 



OCTAL 


DEC. 


OCTAL 


DEC. 


OCTAL 


DEC. 


OCTAL 


DEC. 


.400 


.500000 


.500 


.625000 


.600 


.750000 


.700 


.875000 


.401 


.501953 


.501 


.626953 


.601 


.751953 


.701 


.876953 


.402 


.503906 


.502 


.628906 


.602 


.753906 


.702 


.878906 


.403 


.505859 


.503 


.630859 


.603 


.755859 


.703 


.880859 


.404 


.507812 


.504 


.632812 


.604 


.757812 


.704 


.882812 


.405 


.509765 


.505 


.634765 


.605 


.759765 


.705 


.884765 


.406 


.511718 


.506 


.636718 


.606 


.761718 


.706 


.886718 


.407 


.513671 


.507 


.638671 


.607 


.763671 


.707 


.888671 


.410 


.515625 


.510 


.640625 


.610 


.765625 


.710 


.890625 


.411 


.517578 


.511 


.642578 


.611 


.767578 


.711 


.892578 


.412 


.519531 


.512 


.644531 


.612 


.769531 


.712 


.894531 


.413 


.521484 


.513 


.646484 


.613 


.771484 


.713 


.896484 


.414 


.523437 


.514 


.648437 


.614 


.773437 


.714 


.898437 


.415 


.525390 


.515 


.650390 


.615 


.775390 


.715 


.900390 


.416 


.527343 


.516 


.652343 


.616 


.777343 


.716 


.902343 


.417 


.529296 


.517 


.654296 


.617 


.779296 


.717 


.904296 


.420 


.531250 


.520 


.656250 


.620 


.781250 


.720 


.906250 


.421 


.533203 


.521 


.658203 


.621 


.783203 


.721 


.908203 


.422 


.535156 


.522 


.660156 


.622 


.785156 


.722 


.910156 


.423 


.537109 


.523 


.662109 


.623 


.787109 


.723 


.912109 


.424 


.539062 


.524 


.664062 


.624 


.789062 


.724 


.914062 


.425 


.541015 


.525 


.666015 


.625 


.791015 


.725 


.916015 


.426 


.542968 


.526 


.667968 


.626 


.792968 


.726 


.917968 


.427 


.544921 


.527 


.669921 


.627 


.794921 


.727 


.919921 


.430 


.546875 


.530 


.671875 


.630 


.796875 


.730 


921875 


.431 


.548828 


.531 


■673828 


.631 


.798828 


.731 


.923828 


.432 


.550781 


.532 


.675781 


.632 


.800781 


.732 


.925781 


.433 


.552734 


.533 


.677734 


.633 


.802734 


.733 


.927734 


.434 


.554687 


.534 


.679687 


.634 


.804687 


.734 


.929687 


.435 


.556640 


.535 


.681640 


.635 


.806640 


.735 


.931640 


.436 


.558593 


.536 


.683593 


.636 


.808593 


.736 


.933593 


.437 


.560546 


.537 


.685546 


.637 


.810546 


.737 


.935546 


.440 


.562500 


.540 


.687500 


.640 


.812500 


.740 


.937500 


.441 


.564453 


.541 


.689453 


.a41 


.814453 


.741 


.939453 


.442 


.566406 


.542 


.691406 


.642 


.816406 


.742 


.941406 


.443 


.568359 


.543 


.693359 


.643 


.818359 


.743 


.943359 


.444 


.570312 


.544 


.695312 


.644 


.820312 


.744 


.945312 


.445 


.572265 


.545 


.697265 


.645 


.822265 


.745 


.947265 


.446 


.574218 


.546 


.699218 


.646 


.824218 


.746 


.949218 


.447 


.576171 


.547 


.701171 


.647 


.826171 


.747 


.951171 


.450 


.578125 


.550 


.703125 


.650 


.828125 


.750 


.953125 


.451 


.580078 


.551 


.705078 


.651 


.830078 


.751 


.955078 


.452 


.582031 


.552 


.707031 


.652 


.832031 


.752 


.957031 


.453 


.583984 


.553 


.708984 


.653 


.833984 


.753 


.958984 


.454 


.585937 


.554 


.710937 


.654 


.835937 


.754 


.960937 


.455 


.587890 


.555 


.712890 


.655 


.837890 


.755 


.962890 


.456 


.589843 


.556 


.714843 


.656 


.839843 


.756 


.964843 


.457 


.591796 


.557 


.716796 


.657 


.841796 


.757 


.966796 


.460 


.593750 


.560 


.718750 


.660 


.843750 


.760 


.968750 


.461 


.595703 


.561 


.720703 


.661 


.845703 


.761 


.970703 


.462 


.597656 


.562 


.722656 


.662 


.847656 


.762 


.972656 


.463 


.599609 


.563 


.724609 


.663 


.849609 


.763 


.974609 


.464 


.601562 


.564 


.726562 


.664 


.851562 


.764 


.976562 


.465 


.603515 


.565 


.728515 


.665 


.853515 


.765 


.978515 


.466 


.605468 


.566 


.730468 


.666 


.855468 


.766 


.980468 


.467 


.607421 


.567 


.732421 


.667 


.857421 


.767 


.982421 


.470 


.609375 


.570 


.734375 


.670 


.859375 


.770 


.984375 


.471 


.611328 


.571 


.736328 


.671 


.861328 


.771 


.986328 


.472 


.613281 


.572 


.738281 


.672 


.863281 


.772 


.988281 


.473 


.615234 


.573 


.740234 


.673 


.865234 


.773 


.990234 


.474 


.617187 


.574 


.642187 


.674 


.867187 


.774 


.992187 


.475 


.619140 


.575 


.744140 


.675 


.869140 


.775 


.994140 


.476 


.621093 


.576 


.746093 


.676 


.871093 


.776 


.996093 


.477 


.623046 


.577 


.748046 


.677 


.873046 


.777 


.998046 



C-11 



Rev H 



OCTAL-DECIMAL FRACTION CONVERSION TABLE (Cont'd) 



OCTAL 


DEC. 


OCTAL 


DEC. 


OCTAL 


DEC. 


OCTAL 


DEC. 


.000000 


.000000 


.000100 


.000244 


.000200 


.000488 


.000300 


.000732 


.000001 


.000003 


.000101 


.000247 


.000201 


.000492 


.000301 


.000736 


.000002 


.000007 


.000102 


.000251 


.000202 


.000495 


.000302 


.000740 


.000003 


.00001 1 


.000103 


.000255 


.000203 


.000499 


.000303 


.000743 


.000004 


.00001 5 


.000104 


.000259 


.000204 


.000503 


.000304 


.000747 


.000005 


.000019 


.000105 


.000263 


.000205 


.000507 


.000305 


.000751 


.000006 


.000022 


.000106 


.000267 


.000206 


.000511 


.000306 


.000755 


.000007 


.000026 


.000107 


.000270 


.000207 


.000514 


.000307 


.000759 


.000010 


.000030 


.000110 


.000274 


.000210 


.000518 


.000310 


.000762 


.00001 1 


.000034 


.000111 


.000278 


.000211 


.000522 


.000311 


.000766 


.000012 


.000038 


.000112 


.000282 


.000212 


.000526 


.000312 


.000770 


.000013 


.000041 


.000113 


.000286 


.000213 


.000530 


.000313 


.000774 


.000014 


.000045 


.000114 


.000289 


.000214 


.000534 


.000314 


.000778 


.000015 


.000049 


.000115 


.000293 


.000215 


.000537 


.000315 


.000782 


.000016 


.000053 


.000116 


.000297 


.000216 


.000541 


.000316 


.000785 


.000017 


.000057 


.000117 


.000301 


.000217 


.000545 


.000317 


.000789 


.000020 


.000061 


.000120 


.000305 


.000220 


.000549 


.000320 


.000793 


.000021 


.000064 


.000121 


.000308 


.000221 


.000553 


.000321 


.000797 


.000022 


.000068 


.000122 


.000312 


.000222 


.000556 


.000322 


.000801 


.000023 


.000072 


.000123 


.000316 


.000223 


.000560 


.000323 


.000805 


.000024 


.000076 


.000124 


.000320 


.000224 


.000564 


.000324 


.000808 


.000025 


.000080 


.000125 


.000324 


.000225 


.000568 


.000325 


.000812 


.000026 


.000083 


.000126 


.000328 


.000226 


.000572 


.000326 


.000816 


.000027 


.000087 


.000127 


.000331 


.000227 


.000576 


.000327 


.000820 


.000030 


.000091 


.000130 


.000335 


.000230 


.000579 


.000330 


.000823 


.00003 1 


.000095 


.000131 


.000339 


.000231 


.000583 


.000331 


.000827 


.000032 


.000099 


.000132 


.000343 


.000232 


.000587 


.000332 


.000831 


.000033 


.000102 


.000133 


.000347 


.000233 


.000591 


.000333 


.000835 


.000034 


.000106 


.000134 


.000350 


.000234 


.000595 


.000334 


.000839 


.000035 


.000110 


.000135 


.000354 


.000235 


.000598 


.000335 


.000843 


.000036 


.000114 


.000136 


.000358 


.000236 


.000602 


.000336 


.000846 


.000037 


.000118 


.000137 


.000362 


.000237 


.000606 


.000337 


.000850 


.000040 


.000122 


.000140 


.000366 


.000240 


.000610 


.000340 


.000854 


.000041 


.000125 


.000141 


.000370 


.000241 


.000614 


.000341 


.000858 


.000042 


.000129 


.000142 


.000373 


.000242 


.000617 


.000342 


.000862 


.000043 


.000133 


.000143 


.000377 


.000243 


.000621 


.000343 


.000865 


.000044 


.000137 


.000144 


.000381 


.000244 


.000625 


.000344 


.000869 


.000045 


.000141 


.000145 


.000385 


.000245 


.000629 


.000345 


.000873 


.000046 


.000144 


.000146 


.000389 


.000246 


.000633 


.000346 


.000877 


.000047 


.000148 


.000147 


.000392 


.000247 


.000637 


.000347 


.000881 


.000050 


.000152 


.000150 


.000396 


.000250 


.000640 


.000350 


.000885 


.000051 


.000156 


.000151 


.000400 


.000251 


.000644 


.000351 


.000888 


.000052 


.000160 


.000152 


.000404 


.000252 


.000648 


.000352 


.000892 


.000053 


.000164 


.000153 


.000408 


.000253 


.000652 


.000353 


.000896 


.000054 


.000167 


.000154 


.000411 


.000254 


.000656 


.000354 


.000900 


.000055 


.000171 


.000155 


.000415 


.000255 


.000659 


.000355 


.000904 


.000056 


.000175 


.000156 


.000419 


.000256 


.000663 


.000356 


.000907 


.000057 


.000179 


.000157 


.000423 


.000257 


.000667 


.000357 


.000911 


.000060 


.000183 


.000160 


.000427 


.000260 


.000671 


.000360 


.000915 


.000061 


.000186 


.000161 


.000431 


.000261 


.000675 


.000361 


.000919 


.000062 


.000190 


.000162 


.000434 


.000262 


.000679 


.000362 


.000923 


.000063 


.000194 


.000163 


.000438 


.000263 


.000682 


.000363 


.000926 


.000064 


.000198 


.000164 


.000442 


.000264 


.000686 


.000364 


.000930 


.000065 


.000202 


.000165 


.000446 


.000265 


.000690 


.000365 


.000934 


.000066 


.000205 


.000166 


.000450 


.000266 


.000694 


.000366 


.000938 


.000067 


.000209 


.000167 


.000453 


.000267 


.000698 


.000367 


.000942 


.000070 


.0002 1 3 


.000170 


.000457 


.000270 


.000701 


.000370 


.000946 


.000071 


.000217 


.000171 


.000461 


.000271 


.000705 


.000371 


.000949 


.000072 


.000221 


.000172 


.000465 


.000272 


.000709 


.000372 


.000953 


.000073 


.000225 


.000173 


.000469 


.000273 


.000713 


.000373 


.000957 


.000074 


.000228 


.000174 


.000473 


.000274 


.000717 


.000374 


.000961 


.000075 


.000232 


.000175 


.000476 


.000275 


.000720 


.000375 


.000965 


.000076 


.000236 


.000176 


.000480 


.000276 


.000724 


.000376 


.000968 


.000077 


.000240 


.000177 


.000484 


.000277 


.000728 


.000377 


.000972 



Rev H 



C-12 



OCTAL-DECIMAL FRACTION CONVERSION TABLE (Cont'd) 



OCTAL 


DEC. 


OCTAL 


DEC. 


OCTAL 


DEC. 


OCTAL 


DEC. 


.000400 


.000976 


.000500 


001220 


.000600 


.001464 


000700 


001708 


.000401 


.000980 


000501 


.001224 


.000601 


.001468 


.000701 


001712 


.000402 


.000984 


.000502 


.001228 


.000602 


.001472 


.000702 


.001716 


.000403 


.000988 


.000503 


.001232 


.C00603 


.001476 


.000703 


.001720 


.000404 


.000991 


.000504 


.001235 


.000604 


.001480 


.000704 


001724 


.000405 


.000995 


.000505 


.001239 


.000605 


.001483 


.000705 


001728 


.000406 


.000999 


.000506 


.001243 


.000606 


001487 


000706 


001731 


.000407 


.001003 


.000507 


.001247 


.000607 


.001491 


.000707 


.001735 


.000410 


.001007 


.000510 


.001251 


.000610 


.001495 


.000710 


.001739 


.000411 


.001010 


.000511 


.001255 


.000611 


.001499 


.000711 


.001743 


.000412 


.001014 


.000512 


.001258 


.000612 


.001502 


.000712 


.001747 


.000413 


.001018 


.000513 


.001262 


.000613 


.001506 


.000713 


.001750 


.000414 


.001022 


.000514 


.001266 


.000614 


.001510 


.000714 


.0017 54 


.000415 


.001026 


.000515 


.001270 


.000615 


.001514 


.000715 


.001758 


.000416 


.001029 


.000516 


.001274 


.000616 


.001518 


.000716 


.001762 


.000417 


.001033 


.000517 


.001277 


.000617 


.001522 


.000717 


.001766 


.000420 


.001037 


.000520 


.001281 


000620 


.001525 


.000720 


001770 


.000421 


.001041 


.000521 


.001285 


.000621 


.001529 


.000721 


.001773 


.000422 


.001045 


.000522 


.001289 


.000622 


.001533 


.000722 


.001777 


.000423 


.001049 


.000523 


.001293 


.000623 


.001537 


.000723 


001781 


.000424 


.001052 


.000524 


.001296 


.000624 


.001541 


.000724 


.001785 


.000425 


.001056 


.000525 


.001300 


.000625 


.001644 


.000726 


.001789 


.000426 


.001060 


.000526 


.001304 


.000626 


.001648 


.000726 


.001792 


.000427 


.001064 


.000527 


.001308 


.000627 


.001552 


.000727 


.001796 


.000430 


.001063 


.000530 


.001312 


.000630 


.001566 


.000730 


.001800 


.000431 


.001071 


.000531 


.001316 


.000631 


.001560 


.000731 


.001804 


.000432 


.001075 


.000532 


.001319 


.000632 


.001564 


.000732 


.001808 


.000433 


.001079 


.000533 


.001323 


.000633 


.001567 


.000733 


.001811 


.000434 


.001083 


.000534 


.001327 


.000634 


.001571 


.000734 


.001815 


.000435 


.001087 


.000535 


.001331 


.000635 


.001575 


.000735 


.001819 


.000436 


.001091 


.000536 


.001335 


.000636 


.001679 


.000736 


.001823 


.000437 


.001094 


.000537 


.001338 


.000637 


.001583 


.000737 


.001827 


.000440 


.001098 


.000540 


.001342 


.000640 


.001586 


.000740 


.001831 


.000441 


.001102 


.000541 


.001346 


.000641 


.001590 


.000741 


.001834 


.000442 


.001106 


.000542 


.001350 


.000642 


.001594 


.000742 


.001838 


.000443 


.001110 


.000543 


.001354 


.000643 


.001598 


.000743 


.001842 


.000444 


.001113 


.000544 


.001358 


.000644 


.001602 


.000744 


.001846 


.000445 


,001 117 


.000545 


.001361 


.000645 


.001605 


.000745 


.001850 


.000446 


.001121 


.000546 


.001365 


.000646 


.001609 


.000746 


.001853 


.000447 


.001125 


.000547 


.001369 


.000647 


.001613 


.000747 


.001857 


.000450 


.001129 


.000550 


.001373 


.000650 


.001617 


.0007 60 


.001861 


.000451 


.001132 


.000551 


.001377 


.000651 


.001621 


.000751 


.001865 


.000452 


.001136 


.000552 


.001380 


.000652 


.001625 


.0007 62 


.001869 


.000453 


.001140 


.000553 


.001384 


.000663 


.001628 


.000753 


001873 


.000454 


.001144 


.000554 


.001388 


.000664 


.001632 


.0007 54 


.001876 


.000455 


.001148 


.000555 


.001392 


.000665 


.001636 


.000755 


.001880 


.000456 


.001152 


.000556 


.001396 


.000j656 


001640 


.000756 


.001884 


.000457 


.001155 


.000657 


.001399 


.000657 


.001644 


.000767 


.001888 


.000460 


.001159 


.000560 


.001403 


000660 


.001647 


.000760 


.001892 


.000461 


.001163 


.000561 


.001407 


.000661 


.001661 


.000761 


001895 


.000462 


.001167 


.000562 


.001411 


.000662 


.001655 


.000762 


.001899 


.000463 


.001171 


.000563 


.001415 


.000663 


.001669 


.000763 


.001903 


.000464 


.001174 


.000564 


.001419 


.000664 


.001663 


.000764 


.001907 


.000465 


.001178 


.000565 


.001422 


.000665 


.001667 


000765 


.001911 


.000466 


.001182 


.000566 


.001426 


.000666 


.001670 


,000766 


.001914 


.000467 


.001186 


.000567 


.001430 


.000667 


.001674 


.000767 


.001918 


.000470 


.001190 


.000570 


.001434 


.000670 


.001678 


.000770 


.001922 


.000471 


.001194 


.000571 


.001438 


.000671 


.001682 


.0007 71 


.001926 


.000472 


.001197 


.000572 


.001441 


.000672 


.001686 


.000772 


.001930 


.000473 


.001201 


.000573 


.001445 


.000673 


.001689 


.000773 


.001934 


.000474 


.001205 


.000574 


.001449 


.000674 


.001693 


.000774 


.001937 


.000475 


.001209 


.000575 


.001453 


.000675 


.001697 


.000775 


.001941 


.000476 


.001213 


.000576 


.001457 


.000676 


.001701 


.000776 


.001945 


.000477 


.001216 


.000577 


.001461 


.000677 


.001705 


.000777 


.001949 
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INSTRUCTION FORMATS AND NOTES 



D. INSTRUCTION FORMATS AND NOTES 



The formats below correspond to the mnemonic instructions listed in Table D-1. 



Fl 
F2 

F3 
F4 
F5 
F6 
F7 
F8 
F9 
FIO 

Fll 
F12 



23 


18 17 


1514 














00 








23 


18 17 16 


00 








23 


18 1716 15 14 


00 










23 


18 17 


12 11 00 








23 


18 17 15 14 


12 11 00 










23 


18 1716 15 14 


12 11 00 












23 


18 17 


12 11 09 08 00 










23 


1817 


12 1 1 10 090807 00 














23 


18 17 


12 1 1 10 0706 00 












23 


18 17 16 15 14 


12 11 0605 00 














23 


1817 


12 11 00 








23 


1817 1514 


12 11 00 











D-1 



Rev. A 



18 17 16 



00 



F13 «^ 



23 18 ir 16 



P + 1 



00 



23 18 17 16 00 









F14 <^ 



23 21 20 18 17 16 



P + 1 



00 



23 18 17 16 00 









F15 <^ 



P + 1 



23 212019 18 


17 16 00 















23 18 17 16 



F16 < 



P + 1 



23 



IB 17 16 



00 

Zl 



23 2120 1918 



F17 <^ 



P + 1 



00 

Zl 



P + 2 



ZJ 



23 18 17 16 



23 21 20 1918 1716 



F18 <^ 



P + 1 



ZJ 



P + 2 



23 18 17 16 



: 



D 



23 21 20 19 18 17 16 



F19 



P + 1 



23 18 17 



P + 2 
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F20 



F21 



F22 



F23 



P + 1 



P + 2 



P + 1 



P + 2 



P + 1 



P + 2 



P + 1 



P + 2 



F24 



P + 1 



P + 2 



F25 H P + 1 



P + 2 



23 








8 


17 


16 






02 01 00 










23 


21 20 19 18 17 16 




00 










23 






00 




23 


18 17 16 




02 01 00 










23 


21 20 19 18 17 16 




00 










23 




12 11 


00 






23 


18 17 16 




020100 










23 


2120 19 18 17 16 




00 










23 


20 19 


12 II 


00 








23 


18 17 16 




00 








23 


21 20 19 18 17 16 




02 01 00 












23 




12 II 


00 






23 


IB 17 16 




00 








23 


21 20 19 18 17 16 




02 01 00 












23 


18 17 


12 II 


00 








23 


18 17 




00 






23 


21 20 




00 






23 




12 II 


00 
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23 18 17 16 



00 



23 21 20 19 18 



F26 



P + 1 



18 17 12 11 



P + 2 
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TABLE D-1. INSTRUCTION FORMATS 



Mnemonic 


Basic 






Code 


Octal Code 


Instruction Format 


Page No. 


AC I 


77 


F4 


5-38 


ACR 


77 


F7 


5-40 


ADA, I 


30 


F3 


5-60 


ADAQ, I 


32 


F3 


5-61 


ADM 


67 


P18 


5-68 


AEU 


55 


Fl 


5-36 


AIA 


53 


F6 


5-33 


AIS 


77 


F7 


5-37 


ANA 


17 


Fl 


5-73 


ANA,S 


17 


Fl 


5-73 


ANI 


17 


F3 


5-73 


ANQ 


17 


Fl 


5-74 


ANQ, S 


17 


Fl 


5-74 


AOS 


77 


F4 


5-37 


APF 


77 


F9 


5-39 


AQA 


53 


F5 


5-32 


AQE 


55 


Fl 


5-36 


AQJ, EQ 


03 


F3 


5-46 


AQJ, GE 


03 


F3 


5-46 


AQJ, LT 


03 


F3 


5-46 


AQJ, NE 


03 


F3 


5-46 


ASE 


04 


Fl 


5-29 


ASE, S 


04 


Fl 


5-29 


ASG 


05 


Fl 


5-30 


ASG, S 


05 


Fl 


5-30 


ATD 


66 


F21 


5-119 


ATD, D 


66 


F22 


5-120 


AZJ, EQ 


03 


F3 


5-45 


AZJ, GE 


03 


F3 


5-45 


AZJ, LT 


03 


F3 


5-45 


AZJ, NE 


03 


F3 


5-45 


CIA 


77 


F4 


5-38 


CILO 


77 


F8 


5-91 
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TABLE D-1. INSTRUCTION FORMATS (Cont'd) 



Mnemonic 


Basic 






Code 


Octal Code 


Instruction Format 


Page No. 


CINS 


77 


F5 


5-86 


CLCA 


77 


F8 


5-94 


CMP 


67 


F18 


5-79 


CMP, DC 


67 


F19 


5-80 


CON 


77 


F12 


5-95 


COPY 


77 


F5 


5-83 


CPR, I 


52 


F3 


5-77 


CRA 


77 


F4 


5-40 


CTI 


77 


F4 


5-97 


CTO 


77 


F4 


5-97 


CVBD 


66 


F20 


5-116 


CVDB 


66 


F23 


5-115 


DINT 


77 


F4 


5-89 


DTA 


66 


F23 


5-117 


DTA, DC 


66 


F24 


5-118 


DVA, I 


51 


F3 


5-62 


DVAQ, I 


57 


P3 


5-63 


EAQ 


55 


Fl 


5-36 


ECHA 


11 


F2 


5-26 


ECHA, S 


11 


F2 


5-26 


EDIT 


64 


F18 


5-149 


EINT 


77 


F4 


5-89 


ELQ 


55 


Fl 


5-36 


ENA 


14 


Fl 


5-25 


ENA, S 


14 


Fl 


5-25 


ENI 


14 


F3 


5-25 


ENQ 


14 


Fl 


5-25 


ENQ, S 


14 


Fl 


5-25 


EUA 


55 


Fl 


5-36 


EXS 


77 


F5 


5-83 


FAD, I 


60 


F3 


5-65 


FDV, I 


63 


F3 


5-66 
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TABLE D-1. INSTRUCTION FORMATS (Cont'd) 



Mnemonic 


Basic 






Code 


Octal Code 


Instruction Format 


Page No. 


FMU, I 


62 


F3 


5-66 


FRMT 


64 


F18 


5-147 


FSB, I 


61 


F3 


5-65 


HLT 


00 


Fl 


5-24 


lAI 


53 


F6 


5-33 


lAPR 


77 


F4 


5-113 


IJD 


02 


F3 


5-44 


IJI 


02 


F3 


5-43 


INA 


15 


Fl 


5-27 


INA, S 


15 


Fl 


5-27 


INAC, INT 


73 


F14 


5-106 


INAW, INT 


74 


F14 


5-107 


INCL 


77 


F4 


5-89 


INI 


15 


F3 


5-27 


INPC, INT, B, H, G 


73 


F15 


5-98 


INPW, INT, B, N, G 


74 


F15 


5-100 


INQ 


15 


Fl 


5-27 


INQ, S 


15 


Fl 


5-27 


INS 


77 


F5 


5-85 


INTS 


77 


F5 


5-84 


lOCL 


77 


F4 


5-94 


ISA 


77 


F7 


5-37 


ISD 


10 


F3 


5-31 


ISE 


04 


F3 


5-28 


ISG 


05 


F3 


5-30 


IS I 


10 


F3 


5-31 


JAA 


77 


F4 


5-40 


JMP, HI A 


70 


Fl 


5-42 


JMP, LOW A 


70 


Fl 


5-42 


JMP, ZRO A 


70 


Fl 


5-42 


LACH 


22 


F2 


5-49 


LBR 


70 


Fl 


5-155 
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TABLE D-1. INSTRUCTION FORMATS (Cont'd) 



Mnemonic 


Basic 






Code 


Octal Code 


Instruction Format 


Page No. 


LCA, I 


24 


F3 


5-50 


LCAQ, I 


26 


F3 


5-51 


LDA, I 


20 


F3 


5-49 


LDAQ, I 


25 


F3 


5-50 


LDI, I 


54 


F3 


5-52 


LDL, I 


27 


.F3 


5-50 


LDQ, I 


21 


F3 


5-51 


LPA, I 


37 


F3 


5-73 


LQCH 


23 


F2 


5-52 


MEQ 


06 


Fl 


5-75 


MOVE, INT 


72 


F16 


5-138 


MTH 


07 


Fl 


5-76 


MUA, I 


50 


F3 


5-62 


MUAQ, I 


56 


F3 


5-63 


MVBF 


64 


F18 


5-142 


MVE 


64 


F18 


5-140 


MVE, D 


64 


F19 


5-141 


MVZF 


.64 


F18 


5-143 


MVZS 


64 


F18 


5-144 


MVZS, D 


64 


F19 


5-145 


OSA 


77 


F4 


5-37 


OTAC, INT 


75 


F14 


5-109 


OTAW.INT 


76 


F14 


5-110 


OUTC, INT, B, H 


75 


F15 


5-102 


OUTW,INT,B, N 


76 


F15 


5-104 


PAK 


66 


F18 


5-121 


PA US 


77 


Fll 


5-87 


PFA 


77 


F9 


5-39 


PRP 


77 


Fll 


5-88 


QEL 


55 


Fl 


5-36 


QSE 


04 


Fl 


5-29 


QSE, S 


04 


Fl 


5-29 
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TABLE D-1. INSTRUCTION FORMATS (Cont'd) 



Mnemonic 
Code 


Basic 
Octal Code 


Instruction Format 


Page No. 




QSG 


05 


Fl 


5-30 




QSG, S 


05 


Fl 


5-30 




RAD, I 


34 


F3 


5-60 




RIS 


55 


Fl 


5-112 




ROS 


55 


Fl 


5-112 




RTJ 


00 


Fl 


5-47 




SACH 


42 


F2 


5-54 




SBA, I 


31 


F3 


5-61 




SBAQ, I 


33 


F3 


5-61 




SB CD 


77 


F4 


5-91 




SBJP 


77 


F4 


5-112 




SBM 


67 


F18 


5-69 




SBR 


70 


Fl 


5-155 




SCA, I 


36 


F3 


5-72 




SCAN, LR, EQ. DC 


65 


F26 


5-130 




SCAN, LR,NE,DC 


65 


F26 


5-132 




SCAN, RL, EQ,DC 


65 


F26 


5-134 




SCAN, RL,NE,DC 


65 


F26 


5-136 




SCAN, LR, EQ 


65 


F26 


5-129 




SCAN, LR, NE 


65 


F26 


5-131 




SCAN, RL, EQ 


65 


F2 6 


5-133 




SCAN, RL, NE 


65 


F26 


5-135 




SCAQ 


13 


F3 


5-59 




SCHA, I 


46 


F3 


5-56 




SCIM 


77 


F4 


5-90 




SDL 


77 


F7 


5-113 




SEL 


77 


F12 


5-96 




SFPF 


77 


F4 


5-91 




SHA 


12 


F3 


5-57 




SHAQ 


13 


F3 


5-59 
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TABLE D-1. INSTRUCTION FORMATS (Cont 'd) 



Mnemonic 


Basic 






Code 


Octal Code 


Instruction Format 


Page No. 


SHQ 


12 


F3 


5-59 


SJl 


00 


Fl 


5-41 


SJ2 


00 


Fl 


5-41 


SJ3 


00 


Fl 


5-41 


SJ4 


00 


Fl 


5-41 


SJ5 


00 


Fl 


5-41 


SJ6 


00 


Fl 


5-41 


SLS 


77 


F4 


5-24 


SQCH 


43 


F2 


5-55 


SRCE,INT 


71 


F13 


5-125 


SRCN, INT 


71 


F13 


5-127 


SSA, I 


35 


F3 


5-72 


SSH 


10 


Fl 


5-57 


SSIM 


77 


F4 


5-90 


STA, I 


40 


F3 


5-53 


STAQ, I 


45 


F3 


5-54 


STI, I 


47 


F3 


5-56 


STQ, I 


41 


F3 


5-55 


SWA, I 


44 


F3 


5-56 


TAI 


53 


F6 


5-33 


TAM 


53 


FIO 


5-34 


TIA 


53 


F6 


5-33 


TIM 


53 


FIO 


5-35 


TMA 


53 


FIO 


5-34 


TMAV 


77 


F4 


5-81 


TMI 


53 


FIO 


5-35 


TMQ 


53 


FIO 


5-34 


TQM 


53 


FIO 


5-34 


TST 


67 


F17 


5-82 


TSTN 


67 


F17 


5-82. 


UCS 


77 


F4 


5-24 


UJP, I 


01 


F3 


5-41 
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TABLE D-1, INSTRUCTION FORMATS (Cont'd) 



Mnemonic 


Basic 






Code 


Octal Code 


Instruction Fornaat 


Page No, 










UPAK 


66 


F18 


5-122 


XOA 


16 


Fl 


5-71 


XOA,S 


16 


Fl 


5-71 


XOI 


16 


F3 


5-71 


XOQ 


16 


Fl 


5-71 


XOQ,S 


16 


Fl 


5-71 


ZADM 


67 


F18 


5-146 
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MULTIPROGRAMMING AND RELOCATION 
SUPPLEMENTARY INFORMATION 



E. MULTIPROGRAMMING AND RELOCATION 
SUPPLEMENTARY INFORMATION 



Multiprogramming in the 3300 Computer System enables the instructions of 
many programs to be sequentially executed by controlled time-sharing 
operations within a processor. With the Control Data Multiprogramming Mod- 
ules, throughput is very high due to efficient use of hardware and optimuna 
program scheduling. This feature is very desirable at installations where 
numerous jobs are run and computing time must be kept at a minimum. Systems 
equipped with the relocation feature can compute many programs on a time- 
shared basis or be switched into the non-Executive mode and process jobs 
according to control card job assignments. 



EXECUTIVE MODE 



A system equipped with relocation hardware and operating in the Executive 
Mode functions in either the Monitor State or the Program State. 



Monitor State 



The Monitor State is the initial operating state of a master cleared processor. 
The processor also reverts to this state if interrupted for any condition. All 
instructions may be executed in the Monitor State. 

Program State 



The Program State permits all but the following instructions to be executed: 

1. A Halt instruction (00. 0) 

2. Any of the instructions with function codes in the 71-77 range including the 
UCS, except the SFPF (77.71) and SBCD (77.72) instructions. 

3. An inter-register transfer instruction that attempts to alter registers 
00 through 3 7 of the register file. 
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If an attempt to execute one of these instructions occurs, an Executive interrupt 
is generated and operating control is transferred back to the Monitor State. The 
Executive interrupt is not masked and the interrupt system need not be enabled 
to recognize tne interrupt when it occurs. Upon recognition, the Executive 
interrupt transfers program control to the Monitor State. The instruction that 
caused the interrupt is not executed. The following flow chart describes the 
sequence of events involved when an Executive Interrupt occurs. 



EXECUTIVE INTERRUPT SEQUENCE 



Attempt is made to execute an instruction at 
Address P, that will cause an Executive Interrupt. 



Program control is transferred to the Monitor State. 



Address P is stored in the lower 15 bits of address 
000004 of the Monitor State. 



Interrupt code 0120 is stored in the lower 12 bits of 
address 000005 of the Monitor State. 



Instruction at address 000005 of the Monitor State is 
executed. 



MULTIPROGRAMMING AND RELOCATION 

If the 3311 Multiprogramming option is not present in a 3300 system, the maximum 
number of MCS words is 131,072. The actual address referenced is as follows: 



0100 14 



(ISR)- 



-[m 



I OR ; 

Dl OOi 



(OSR) *\\J] 



I OR 
"00' 



Upper Bit of ISR 
or OSR is ignored 



17 BIT ADDRESS 

ft 



00 



(P) 



Refer to Table E-1 for conditions 
when (ISR), (OSR), or zero is 
appended to address P. 



Rev. A 



E-2 



If the APF (77. 64) or PFA (77. 65) instructions are executed they become no- 
operation instructions when the 3311 is not present. The keyboard sweep and enter 
functions with the Page Index File are also disabled. All other operating conditions 
are the same whether or not the 3311 is in the system. 

A 3300 CPU can access up to 262, 144 words of core storage when the 3311 
Multiprogramming option and appropriate storage modules are present in the 
system. This is accomplished by augmenting the basic 15-bit address P with a 
3-bit state number. The state number, along with a portion of the 15-bit address, 
becomes the direction path into a relocation path. From the Page Index File the 
correct page address is obtained for actual memory addressing. 

Page Structure 

Each page of memory is assigned 2, 048 absolute memory locations. A fully 
expanded system contains 128 of these pages. Individual pages may be sub- 
divided into four partial pages. A 1/4 page consists of 512 address locations. 
Programs may be allocated full pages, 3/4 page, 1/2 page or 1/4 page of 
memory. 

To facilitiate addressing with the paging scheme, a word organized core 
matrix is used. This core matrix, called the Page Index File, is referenced 
by a program during a memory reference to obtain the physical page address 
or partial page address and provide memory protection. 

Address Relocation 

Figure E-1 illustrates address bits at various stages of the relocation process. 
Those portions of the diagram accompanied by circled numbers are further 
described in the following numbered paragraphs. 

(T) Program Address and Program Address Group 

Any program executed by a 3300 is processed within the confines of a 15-bit 
program address structure. These 15 bits define the program or operand 
address related to the routine or subroutine being processed at a given instant. 
Figures E-2 and E-3 illustrate the significance of these bits in the instruction 
words for both word addressing and character addressing. 

The 15 bits used in word addressing define an absolute address assignment 
ranging from 00000 to 77777o. Any program or group of programs within this 
range of addresses which can be compiled and loaded without conflicting add- 
resses can be considered part of a program address group. Figure E-4is 
illustrative of a program address group consisting of five non-conflicting 
programs. 
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© 



7— BIT 

PAGE FILE 

ADDRESS' 

(INPUT) 

I i 



® 

(ISR) 

OR < 
(OSR) 



02 
00 





..}■ 





14 






II 
10 


III 


© 


09 
08 


III 


PROGRAM . 
ADDRESS 








00 





>-" 



PAGE 

INDEX 

FILE 



-I BIT— 
-2BITS- 



12 BIT 

PAGE JNDEX 

(OUTPUT) 



-7 BITS- 



-2 BITS- 



PAGE 

LENGTH 

CONTROL 



ILLEGAL WRITE 



(REF TO TEXT FOR 
ADDITIONAL INFORMATION 
ON NUMBER AREAS) 



17 




00 



® 



18-BIT 

RELOCATED 

MEMORY 

ADDRESS 



■RELATIVE BIT POSITION 



Figure E-1. Address Relocation Process 
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A program address group may be considered apart from the physical memory 
structure since it is a group of sequentially nunabered addresses representing 
one or more programs within 32, 768 words of storage and not a discrete 
physical device. Many program address groups may be contained in storage; how- 
ever, eight such groups are used in the 3300 to best optimize the memory system. 
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Figure E-2. Word Addressing 
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Figure E-3. Character Addressing 



Instruction State Register (ISR) and Operand State Register (OSR) 



The ISR and OSR define the specific program address group currently being 
accessed by a processor. The program address group being referenced for 
instructions and operands can assume any one of eight discrete values by 
modifying the contents of these single digit registers. By transferring dis- 
similar numbers into these registers, instructions and operands may ref- 
erence different program address groups. 

The contents of these registers can only be changed by the Executive routine in 
the Monitor State. 

The program address group that is currently valid for memory references is 
selected by the contents of the ISR or OSR. Table E-1 describes the selecting 
conditions. 
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Figure E-4. Program Address Group 



TABLE E-1. INSTRUCTION AND OPERAND REFERENCING 



Operational State of the Processor 


Instructions 
Referenced With: 


Operands 
Referenced With: 


Initial Monitor State 


Zero 


Zero 


Monitor State and 55.4 (relocate 
to operand state) instruction 
executed 


Zero 


Contents of OSR 


Transition from Monitor State to 
Program State 


Contents of ISR 


Contents of ISR* 


Program State and 55.4 (relocate 
to operand state) instruction 
executed 


Contents of ISR 


Contents of OSR 


Program State and 55.0 (relocate 
to instruction state) instruction 
executed 


Contents of ISR 


Contents of ISR 


Any interrupt condition to 
Monitor State 


Zero 


Zero 



!=Transition from Monitor State to Program State does not change the operand 
address mode. 
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Page Index File 



The Page Index File is functionally divided into eight distinct reference areas. 
One area is associated with each of eight possible numbers appearing in the ISR 
and OSR. Because of this direct relationship, each of the eight program address 
groups is permanently assigned a reference area in the Page Index File. 

Each of the eight reference areas within the Page Index File consists of sixteen 
12-bit Page Index Registers. This provides each of the program address groups 
exclusive use of 16 of these registers. By using the upper 4 bits of the program 
address for direction to the respective Page Index Registers, a direct and 
sequential relationship is established between the addresses in a program ad- 
dress group and a specific set of 16 Page Index registers. The Page Index File 
is actually constructed of 64 24-bit Page Index registers with dual 12 -bit in- 
dexes. Only one of the 12-bit indexes is used during any specific reference. 

Figure E-6 depicts the page indexes within the Page Index File and Figure E-7 
illustrates the relationship between program address groups. Page Index File, 
and a fully expanded core memory. 

Bit 11 of the original 15-bit address determines which of the two page indexes 
at the Page File location will be used. Figure E-5 shows a specific page index 
being referenced. 
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The contents of this Page Index (E, 
PL, PA, and PP) are used to form 
the relocated' address. The format 
of a page index is shown below. 
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Figure E-5. Example of Page Index Referencing 
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■THIS DIBIT INDICATES 
PROGRAM STATE NUMBER 
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Figure E-6. Page Index File Address and Hardware Structure 
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PAGE INDEX 
REGISTERS 
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GRAM ADDRESS 
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OF ONE OR MORE 
INDIVIDUAL PRO- 
GRAMS WITHIN 
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Figure E-7. Relocation System Illustrating Menaory Protection 
with Fully Expanded Memory (262K) 
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(D Page Index 

Each page index has the same basic format. The significance of each designator 
during the relocation process is described below. Figure E-8 shows the format 
for a page index while Figure E-9 shows a view of the display panel on the re- 
location chassis. 
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E = EXCLUSION BIT (I BIT) 
PL = PAGE LENGTH DESIGNATOR (2 BITS) 
PA = PAGE ADDRESS DESIGNATOR (7 BITS) 
PP= PARTIAL PAGE DESIGNATOR (2 BITS) 



Figure E-8. Page Index Format 



E - Exclusion bit 



This designator may have one of three meanings: 

1. If E = "O", the quantity expressed by PA defines a page* 
where either reading or writing is permitted. 

2. If E = "l", and PL, PA or PP is a quantity other than 
zero, PA defines a page * where only reading is per- 
mitted. If a write is attempted, an Illegal Write inter- 
rupt is generated. 

3. If E = "1" and PL, PA Or PP are all equal to zero, 
an unaddressable page is defined and an Illegal Write 
interrupt is generated by the Page Index File. 

* Refer to descriptions of PL and PP designators for page restrictions. 
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Figure E-9. Relocation Chassis Display Panel 
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PA - Seven bits are used to define the actual memory module being referenced. 
As stated earlier in this manual, there may be 128 segmented pages in a 
3300 system with 262, 144 words of core storage. Each page has 
a unique page address and addresses 000 through 1778 define all of the 
possible pages. 

A 3300 system with a fully expanded storage network has two address 
busses. Each bus has access to 131,072 words of the total 262, 144 
storage words. The uppermost bit of PA (bit 17 in the relocated address) 
determines which bus (right or left) is selected. This bit will be a "l" 
when the left bus is used and a "O" when the right bus is selected. Figure 
E-10 depicts the bus address system. 
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Figure E-10. Storage Address Buses 
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Figure E-11. Page Length Subdivisions 
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PL - Each page has 2, 048 memory locations and is subdivided into quarters of 
512 locations each. The PL designator defines how many quarters of a 
page can be referenced (beginning with the starting quarter specified by 
PP). A program is assigned the number of quarter pages it needs to re- 
side in memory. Figure E-11 illustrates the quarter sections of a page 
and the significance of the PL bits. 

PP - The Partial Page designator is the address of the physical quarter page 

that will serve as the starting point of the page. Example A (Figure E-12) 
shows the quarter page referenced for each of the PP designators. The 
significance of the PP designator in selecting the respective quarter page 
for addressing is described below.. 

EXAMPLE A 



PHYSICAL 
QUARTER 
DESIGNATOR 



RELATIVE QUARTER 
IN RESPECT TO THE 
STARTING QUARTER 



STARTING QUARTER 
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Figure E-12. Quarter Page in Relation to PP Designator 
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If PP = 0, the relative page begins in the 1st physical quarter 
If PP = 1, the relative page begins in the 2nd physical quarter 
If PP = 2, the relative page begins in the 3rd physical quarter 
If PP = 3, the relative page begins in the 4th physical quarter 

d) Partial Page Adder 

A special adder is used to combine the PP designator from the page index with 
bits 9 and 10 of the original address. The partial sum indicates the address of the 
physical quarter in which referencing will begin. Example B and Figure E-13 
show the actual quarter page in which addressing occurs for specific PL, PP, and 
bits 9 and 10 values. 



EXAMPLE B 



PL = 
PP = 1 

Bits 9 and 10 = 2 

Analysis: A full page (PL = 0) is allocated, the relative page 
begins in the second physical quarter, and referen- 
cing begins in the fourth physical quarter, (physical 
quarter address 3). 

RELATIVE QUARTERS 



STARTING QUARTER 

PP= I 

BITS 9 AND 10 = 2 



|S^ QUARTER 
2_ND^ QUARTER_ 
2^^ QUARTER 
4^"" QUARTER 



ADDRESSING STARTS IN THE 
THIRD RELATIVE QUARTER 
(FOURTH PHYSICAL QUARTER) 

Figure E-13. Starting Quarters versus Relative Quarters 

It should be noted that if bits 9 and 10 of the original address specify a quarter 
page equal to or greater than that of the PL designator when PL f zero, an Illegal 
Write interrupt will occur. An example of this condition would be a 1/4 page 
allocated but bits 9 and 10 equal to 3, thus specifying an address in the fourth 
quarter. 

This interrupt will not occur during Monitor State or I/O operations. 
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© Relocated Address 

The 18-bit relocated address defines the actual core storage location being 
referenced. 

The PA portion of the page index fills the upper seven bits of this address (S) 
bus to use and select the appropriate storage module. Bits 9 and 10 receive the 
output of the adder previously described and indicate the physical quarter page 
being referenced. The lower nine bits are unaltered from the original address 
and comprise the remainder of the relocated address. 

Page Zero Consideration 

If page Index File address zero is referenced in either the Program or Monitor 
state, the PA and PP designators for this page index will always be zero. As 
a result of this condition, page zero, which encompasses addresses 000000 
through 003777, can be accessed and used for storing the Auto Load and Auto 
Dump routines. The Auto Load routine is contained in addresses 003700 
through 003737 and the Auto Dump routine is stored in addresses 003740 through 
003777. 
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F. BUSINESS DATA PROCESSING SUPPLEMENTARY INFORMATION 



The performance of a 3300 computing systein is further enhanced by the addition 
of a 3312 Business Data Processor (BDP) which eliminates the need for simulating 
subroutines. Business-oriented rnoves and edits, searches, code conversions and 
translations as well as BCD arithmetic operations are executed directly by the 
BDP. Since the BDP is designated as an integral part of the computer system and 
interfaces directly to the magnetic core storage modules, the instructions are 
executed with great speed. The BDP expands the basic instruction repertoire to 
cover instructions inherent to business data processing applications. 

The logical organization of the BDP and its comprehensive instruction repertoire 
emphasizes its usefulness as a logical field processor. This organization per- 
mits truly efficient processing of highly structured data files. Some examples 
of applications which exploit these features are data collection, production con- 
trol, inventory accounting, and financial and accounting systems. 



CHARACTERISTICS OF BDP 

The following are characteristics of the 3300 Business Data Processor: 

m Character addressing and manipulation 

internal BCD 6-bit characters 
24-bit words 

Manipulation of data organized in variable or fixed length fields 

Memory to memory operations 

Field limits expressed by either programmer -defined delimiter 
or by length 

COBOL specification compatibility 

Error indications on arithmetic overflow and illegal characters 

Algebraic sign control 
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• Extremely fast and coraprehensive data processing instruction set 

moves and edits 

searches 

ASCII/ BCD code conversions and translations 

arithm.etic functions 

• System interrupt capability retained without loss of data 

Business data processing instructions are listed in Section 5. A general de- 
scription of each of the instruction categories is listed below: 



MOVES AND EDITS 

The following capabilities are features of this instruction category: 

• Ability to transfer variable length data fields from one area 
of storage 

• Both fields may specify any 6 -bit character location in storage 
as the beginning address 

• Both fields may be independently indexed 

• Up to 4095 characters may be processed 

• Operations may be terminated by specifying lengths of fields 
or by encountering delimiting characters; field lengths may 
differ 

• Data moved from a source field to a receiving field may be 
manipulated and/ or modified as follows: 

► Single character or block of characters transferred without 
modification 

► Move with blanks inserted in any remaining character 
positions in the receiving field 

► Move with zeros inserted in any remaining character 
positions in the receiving field 

► Move with leading zeros replaced with blanks and zone 
(sign) bits stripped during the transfer 

► Move with edit functions perforraed: insertion of commas, 
decimal point with suppression of leading zeros, or complete 
formatted edit with insertion of character set as defined in 
DOD COBOL-61 Extended specification 

Instructions in this group are particularly useful in data processing applications 
involving character manipulation, formatting for printing of integer quantities, 
point alignment problems, etc. Editing functions are accomplished by hardware 
rather than a complex subroutine, resulting in extremely fast processing times. 
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SEARCHES 

The following capabilities are features of this category of instructions: 

(9 Any 6 -bit character location in storage may be specified as 
the location of the first character to be searched 

• Up to 4095 characters may be examined 

o Indexing may be accomplished on the search field 

• Search key (character) specified by programmer and contained 
in instruction word 

• Search may be terminated by: 

► Locating object character 

► Completing specified number of searches without 
locating object character 

► Encountering delimiter -character without locating 
object character 

• At conclusion of search operation, an index register holds number of 
characters searched to aid in determining location of character meeting 
search condition; this information placed in Central Processor Index 
register 

• Program control at search termination branches to either of two points ; 
depending on result of search 

• Searches may be of the following types: 

► Search successive character locations (either left to right 
or right to left) in a field for an object character equal to 
the search key 

► Search successive character locations (either left to right 
or right to left) in a field for an object character unequal 
to the search key 

► Search successive character locations (from left to right) 

in a field for an object character equal to the search key and 
jump; jump is to normal termination point plus the number 
of characters searched 



CONVERSIONS AND TRANSLATIONS 

Instructions in the category provide conversion and translation abilities to ef- 
ficiently process data of varying formats. Translating codes prepares data for 
various operations preliminary to the actual data processing. Translations to 
and from the American Standard Code for Information Interchange (ASCII) code 
provide compatibility with other systems data handling schemes. An ASCII to 
BCD conversion table can be found in Appendix A. 
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The following conversions and translations may be effected with this category of 
instructions: 

• Convert BCD to binary 

Convert binary to BCD 

Translate to ASCE 

Translate from ASCII 

Pack (convert numeric 6-bit digits into 4-bit BCD characters) 

Unpack (convert numeric 4 -bit digits into 6 -bit characters) 

ARITHMETIC FUNCTIONS 

The following capabilities are features of this category of instructions: 
Arithmetic performed on 6 -bit BCD characters 
Both fields may specify any 6-bit character location in storage 
as the beginning address 
Both fields may be independently indexed 
Algebraic sign control 

Arithmetic overflow fault indicator provided 
Arithmetic operations from right to left 
Compare - comparisons of two fields for equal, unequal 

► Compare left to right 

► Delimiter or number of characters (up to 4095) 
specifies number of characters to be compared 

► High-low indication held in condition register 
for examination by Jump instructions 

• Test instructions examine field for: greater than zero, 
zero, or less than zero. The result of the test sets a 
BCD condition register to +, 0, or - 

o Jump instructions in the CPU may be used to examine 
arithmetic result flags in the BDP 

Consult the individual business data processing instructions in Section 5 for 
detailed information pertaining to each type of instruction. 



BCD CHARACTERS AND ALGEBRAIC SIGN POSITIONS 

Six-bit BCD characters are used during most BDP operations. The following 
diagrams, example, and tables show the character placements and sign positions: 
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-Character positions- 
BCD Character 
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Character bits 



Figure F-1. BCD Word and Character Format 



TABLE F-1 . BCD SIGN BIT POSITIONS 



Sign of BCD 
Field 


Relative Bit Positions 
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+ 

+ 

+ 
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TABLE F-2, DECIMAL/ BCD CHARACTER FORMAT 
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Number 


BCD Character Relative Bit 
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EXAMPLE: Execute the MVZF instruction at P, P + 1, and P + 2. 



p 


= 64000202 


p + 1 = 


= 27003000 


P + 2 = 


= 140017 



(B ) = 00200 
(B^) = 01000 



Analysis: 

1. The unmodified character address 'r' is 00202. 

2. B = 3, requiring (B^ be added to r. If (B^) = 00200 then 
R^= 00402 which equals word address 00100 character position 

2. This is the true address of the highest order character in field A. 

3 B = 2, requiring;^(B^) be added to the unmodified character address 
's\ 03000. If (B^) = 01000, then S = 04000. 

4. The length of the A field is 14^ characters and the alloted length of the C 
field is 17o characters. The fast three characters of field C will be 
filled with zeros. The last character of field C (a zero) will also contain 
the sign of the field. 



Character Positions 



'A' Field 
Word Addresses 
10 
10 1 
10 2 
10 3 






1 


2 


3 



1 
1 
6 








6 (0 4/ 3 
11 2 4 
3 11 10 



5 (5~l) 4 7 



Lowest Order 
Character in 
Field A 



Highest Order 
Character in 
Field A 



Operand Specified 
in Field A Equals 
-431924639859 



Indicates a 
Negative Field 




Indicates Character 
Is lis = 9io 
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The operation proceeds as follows: 



First Character Stored Is 
Highest Order Character At 
Word Address 01000, Char- 
acter Position Zero. 



'C Field 




/ 






ord Addresses 




/ 






7 7 7 


3 / 


1 
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10 


(0 4) 


3 


1 


1 1 


10 1 


2 


4 


6 


3 


10 2 


1 1 


1 


5 


1 r 


10 3 








(4 0) 


7 



^Sign Is No Longer Stored 
In This Character As The 
Lowest Order Character 
Of Field C Is Now Char- 
acter Position 2 Of Word 
Address 01003. 



Lowest Order Character 
In Field C Contains the 
Sign of Field C (minus) 
and a Zero Character. 



Operand Now Stored 
In Field C Equals 
-431924639859000 
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GLOSSARY 



The definitions of terms in this glossary are general, and are oriented toward 
their application to the 3300 computer. The definitions should not be construed as 
absolute or applicable for all Control Data products. 

A REGISTER - Principal arithmetic register; operates as a 24-bit additive 
accumulator (modulus 224-1), 

ABSOLUTE ADDRESS - An address at a specific memory location. 

ACCESS TIME - The time needed to perform a storage reference, either read 
or write. In effect, the access time of a computer is one storage reference 
cycle. 

ACCUMULATOR - A register with provisions for the addition of another quantity 
to its content. 

ADDER - A device capable of forming the sum. of two or more quantities. 

ADDRESS - A 15-bit operand which identifies a particular storage location; a 
17-bit operand which identifies a particular character location in storage. 

ADDRESS MODIFICATION - Normally the derivation of a storage address from 
the sum of the execution address and the contents of the specified index 
register. 

AND FUNCTION - A logical function in Boolean algebra that is satisfied (has 

the value "l") only when all of its terms are "I's". For any other combina- 
tion of values it is not satisfied and its value is "O". 

ARGUMENT - An operand or parameter used by a program or an instruction. 

ASCII CODE - American Standard Code for Information Interchange 8 -bit 
character code (eighth bit is actually unassigned). 

ASSEMBLER - A program which translates statements to machine language. 
Normally, one source language statement results in the generation of one 
line of object code. 
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B-"-, B^, B^ REGISTERS - Index registers used primarily for address modifi- 
cation and/ or counting. 

BASE - A quantity which defines some system of representing numbers by 
positional notation; radix. 

BDP - (1) Business Data Processor (3312); provides the necessary hardware 
to execute business oriented instructions. Contains its own translation 
and control logic but must be used with CPU. 

(2) Business Data Processing; processing business oriented data. 

BINARY CODED DECIMAL (BCD) - A form of decimal notation where decimal 
digits are represented by a binary code. 

BIT - Binary digit, either "l" or "O". 

BLOCK - A sequential group of storage words or characters in storage. 

BOOTSTRAP - Any short program which facilitates loading of the appropriate 
system executive. 

BREAKPOINT - A point in a routine at which the computer may be stopped by 
manual switches for a visual check of progress. 

BUFFER - Any area that is used to hold data temporarily for input or output, 
normally storage. 

BYTE - A portion of a computer word, usually 6 or 12 bits. 

CAPACITY - The upper and lower limits of the numbers which may be processed 
in a register or the quantity of information which may be stored in a storage 
unit. If the capacity of a register is exceeded, an overflow is generated. 

CHANNEL - An input/ output (I/O) transmission path that connects the computer 
to an external equipment; 3306 or 3307. 

CHARACTER - A group of bits which represents a digit, letter, or symbol 
from the typewriter. 

CLEAR - An operation that removes a quantity from a register by placing every 
stage of the register in the "O" state. The initial contents of the register 
are destroyed by the Clear operation. 

COMMAND - A control signal; also used synonymously with Instruction. 

COMPILER - A program with the capability to generate more than one line 
of machine code (instruction or data word) from one source language 
statement. 

COMPLEMENT - Noun: See One's Complement or Two's Complement. Verb: 
A command which produces the one's complement of a given quantity. 

CONTENT - The quantity or word held in a register or storage location. 
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CORE - A ferromagnetic toroid used as the bi- stable device for storing a bit in 
a memory plane. 

COUNTER - A register or storage location, the contents of which may be in- 
cremented or decremented. 

CPU - Central Processing Unit; controls all sequential operations within the 
computer. See Main Control. 

D - Delimiting indicator (refer to Delimiting). 

DELIMITING - During a BDP character operation, character delimiting may 
sometimes be used where the operation is terminated if during the course 
of the operation a character is recognized as equal (or unequal in some 
instructions) to a fixed comparison (or delimiting) character. 

DOUBLE PRECISION - Providing greater precision in the results of arithmetic 
operations by appending 24 additional bits of lesser significance to the 
initial operands. 

ENTER - The operation where the current contents of a register or storage 
location are replaced by some defined operand. 

EQUALIZE - Adjusting the operand of the algebraically smaller exponent to 

equal the larger prior to adding or subtracting the floating point coefficients. 

EXCLUSIVE OR - A logical function in Boolean algebra that is satisfied (has 
the value "l") when any of its terms are "l". It is not satisfied when all 
its terms are "l" or when all its terms are "O". 

EXECUTION ADDRESS - The lower 1 5 or 17 bits of a 24-bit instruction. Most 
often used to specify the storage address of an operand. Sometimes used 
as the operand. 

EXECUTIVE MODE - An operating mode in which address relocation may occur. 
An efficient operating mode consisting of two possible states: Monitor 
State and Program State. 

EXIT - Initiation of a second control sequence by the first, occurring when the 
first is near completion; the circuit involved in exiting. 

F REGISTER - Program Control register. Holds a program step while the 
single 24-bit instruction contained in it is executed. 

FAULT - Operational difficulty which lights an indicator or for which interrupt 
may be selected. 

FILE MANAGER - A software system operating in conjunction with MSIO and 
providing a central repository for all data accruing in a particular data 
center, i.e. , a system which creates a file for the user. 

FIXED POINT - A notation or system of arithmetic in which all numeric quan- 
tities are expressed by a predetermined number of digits with the binary 
point implicitly located at some predetermined position; contrasted with 
floating point. 
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FLIP-FLOP (FF) - A bi-stable storage device. A "l" input to the set side 
puts the FF in the "l" state; a "l" input to the clear side puts the FF in 
the "O" state. The FF remains in a state indicative of its last "l" input. 
A stage of a register consists of a FF. 

FLOATING POINT - A means of expressing a number, X, by a pair of numbers, 
Y and Z, , such that X = Yn^. Z is an integer called the exponent or 
characteristic; n is a base, usually 2 or 10; and Y is called the fraction or 
mantissa. 

FUNCTION CODE - See Operation Code. 

INCREASE - The increase operation adds a quantity to the contents of the 
specified register. 

INDEX DESIGNATOR - A 2-bit quantity in an instruction; usually specifies an 
index register whose contents are to be added to the execution address; 
sometimes specifies the conditions for executing the instruction. 

INDIRECT ADDRESSING - A method of address modification whereby the lower 
18 bits of the specified address become the new execution address and 
index designator. 

INSTRUCTION - A 24- or 48-bit quantity consisting of an operation code and 
several other designators. 

INTEGRATED REGISTER FILE - The upper 64io locations of core storage; re- 
served for special operations with Block Control. 

INTERRUPT - A signal which results in transfer of control, following comple- 
tion of the current instruction cycle, to a fixed storage location. 

INTERRUPT REGISTER - A 24-bit register whose individual bits are set to "l" 
by the occurrence of specific interrupt conditions, either internal or 
external. 

INTERRUPT MASK REGISTER - A 24-bit register whose individual bits match 
those of the Interrupt register. Setting bits of the Interript Mask register 
to "I's" is one of the conditions for selecting interrupt. 

INVERTER - A circuit which provides as an output a signal that is opposite to 
its input. An inverter output is "l" only if all the separate OR inputs are 
"0". 

ISR - Instruction State Register; 3-bit register defining the program address 
group being referenced for instructions. 

JUMP - An instruction which alters the normal sequence control of the com- 
puter and, conditionally or unconditionally, specifies the location of the 
next instruction. 

LIBRARY - Any collection of programs (routines) and/ or subprograms 
(subroutines). 
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LOAD - The Load operation is composed of two steps: a) the register is 
cleared, and b) the contents of storage location M are copied into the 
cleared register. 

LOCATION - A storage position holding one computer word, usually designated 
by a specific address. 

LOGICAL PRODUCT - In Boolean algebra, the AND function of several terms. 
The product is "l" only when all the terms are "l"; otherwise it is "O". 
Sometimes referred to as the result of bit-by-bit multiplication. 

LOGICAL SUM - In Boolean algebra, the OR function of several terms. The 
sum is "l" when any or all of the terms are "l"; it is "O" only when all 
are "O". 

LOOP - Repetition of a group of instructions in a routine. 

MACRO CODE - A method of defining a subroutine which can be generated 
and/or inserted by the assembler. 

MAIN CONTROL - The sequence of events within the CPU controlling the 
various operations of program execution; synonomous with Program 
Control. 

MASK - In the formation of the logical product of two quantities, one quantity 
m.ay mask the other; i.e. , determine what part of the other quantity is to 
be considered. If the mask is "O", that part of the other quantity is un- 
used; if the mask is "l", the other quantity is used. 

MASTER - Multiple Access, Shared Time, Executive Routine; an advanced 

time-sharing operating system for 3300 and 3500 computers equipped with 
the 3311 multiprogramming option. 

MASTER CLEAR - A general command produced by pressing one of three switches; 
a) Internal Master Clear - clears all operational registers and control 
FFs in the processor; b) External Master Clear - clears all external equip- 
ments and the communication channels; c) Master Clear - a keyboard switch 
that performs both an Internal and External clear. 

MCS - Magnetic Core Storage; see CORE. 

MNEMONIC CODE - A three -or four -letter code which represents the function 
or purpose of an instruction. Also called alphabetic code. 

MODULUS - An integer which describes certain arithmetic characteristics of 

registers, especially counters and accumulators, within a digital computer. 
The modulus of a device is defined by r"^ for an open-ended device and r"--l 
for a closed (end-around) device, where r is the base of the number system 
used and n is the number of digit positions (stages) in the device. Generally, 
devices with modulus r'^ use two's complement arithmetic; devices with 
modulus r"^-! use one's complement. 

MONITOR STATE - An operating state under Executive mode in which all 3300 
instructions may be executed. If the 3311 Multiprogramming option is in a 
system, address relocation is possible. 
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MSIO - Mass Storage Input/ Output; a basic file oriented I/O program for 
operating with mass storage devices and magnetic tape units. 

MULTI-PROCESSING- Simultaneous instruction processing; multi-processing 
is accomplished in the 3 300 by using an additional CPU. 

MULTIPROGRAMMING - Alternately servicing instructions from two or more 
programs as opposed to completing one job at a time. Multiprogramming 
utilizes the time -sharing capabilities of the computer under the guidance 
of an executive monitor. 

NON-EXECUTIVE MODE - An operating mode in which instructions are 

sequentially executed and which permits a 3300 to perform identically to a 
3200. 

NO-OP - No-Operation. 

NO -OPERATION - Usually an undefined octal code that produces no useful 

function. Some 3300 instructions are No-Operation (NO-OP) instructions 
if execution is attempted in non-Executive mode. 

NORMALIZE - To adjust the exponent and mantissa of a floating point result so 
that the mantissa lies in the prescribed standard (normal) range. 

NORMAL JUMP - An instruction that jumps from one sequence of instructions 
to a second and makes no preparation for returning to the first sequence. 
Also referred to as an unconditional jump. 

NUMERIC CODING - A system of abbreviation in which all information is re- 
duced to numerical quantities. Also called absolute or machine language 
coding. 

OBJECT PROGRAM - The machine language version of the source program. 

ONE'S COMPLEMENT - With reference to a binary number, that number which 
results from subtracting each bit of a given number from '^l". The one's 
complement of a number is formed by complementing each bit of it indi- 
vidually, that is, changing a "l" to "O" and a "O" to a "l". A negative 
number is expressed by the one's complement of the corresponding positive 
number. 

ON-LINE OPERATION - A type of system application in which the input or 
output data to or from the system is fed directly from or to the external 
equipment. 

OPERAND - Usually refers to the quantity specified by the execution address. 

OPERATION CODE (Function Code) - A 6-bit quantity in an instruction 
specifying the operation to be performed. 

OPERATIONAL REGISTERS - Registers which are displayed on the operator's 
section of the console. 
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OR FUNCTION - A logical function in Boolean algebra that is satisfied (has 
the value "l") when any of its terms are "l". It is not satisfied when all 
terms are "O". Often called the inclusive OR function. 

OSR - Operand State Register; 3-bit register defining the program address group 
being referenced for operands. 

OVERFLOW - The capacity of a register is exceeded. 

P REGISTER - The Program Address Counter (P register) is a one's comple- 
ment additive register (modulus 2l5-i) which defines the storage addresses 
containing the individual program steps. 

PAGE - 2,048 absolute memory locations which may be subdivided into four 
partial pages. Storage allocation is made in whole number multiples of 
quarter pages. 

PAGE INDEX FILE - A word-organized core matrix consisting of 12-bit page 
indexes. The contents of the page indexes are used during address 
relocation. 

PARAMETER - An operand used by a program or subroutine. 

PARITY CHECK - A summation check in which a group of binary digits 

are added and the sum checked against a previously computed parity digit; 
i.e. , a check which tests whether the number of ones is odd or even. 

PICTURE - A compact way of describing a data item. Among the things it may 
specify are size, class, sign, and editing. 

PROGRAM - A precise sequence of instructions that accomplishes the solution 
of a problem. Also called a routine. 

PROGRAM ADDRESS GROUP - A group of sequentially numbered addresses 
representing one or more programs within 32,768 words of storage. It 
is not a discrete physical device. 

PROGRAM ADDRESS REGISTER - Synonomous with P register. 

PROGRAM CONTROL - Synonomous with Main Control. 

PROGRAM STATE - A highly efficient operating state of Executive mode in 

which all 3300 instructions may be executed except those instructions that 
call for I/O operations, alter certain register file locations, or halt the 
computer. 

PROGRAM STATE NUMBER - One of seven Program Address Groups. 

PSEUDO CODE - A statement requesting a specific operation by the assembler 
or compiler. 

Q REGISTER - Auxiliary 24-bit arithmetic register which assists the A register 
in the more complicated arithmetic operations. 
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RADIX - The number of different digits that can occur in a digit position for a 
specific number system. It may be referred to as the base of a number 
system. 

RANDOM ACCESS - Access to storage under conditions in which the next 

position from which information is to be obtained can be independent of the 
previous one. 

READ - To remove a quantity from a storage location. 

REGISTER - The internal logic used for temporary storage or for holding a 
quantity during computation. 

REJECT - A signal generated under certain circumstances by either the exter- 
nal equipment or the processor during the execution of I/O instructions. 

RELOCATION - Making efficient use of all memory locations by reassignment 
through the use of a memory paging system under control of a monitor 
program. 

REPLACE - When used in the title of an instruction, the result of the execution 
of the instruction is stored in the location from which the initial operand was 
obtained. When replace is used in the description of an instruction, the 
contents of a location or register are substituted by the operand. The 
Replace operation implies clearing the register or portion of the register 
in preparation for the new quantity. 

REPLY - A response signal in I/O operations that indicates a positive response 
to some previous operation or request signal. 

REPORT GENERATOR - A language and compiler to reduce the programming 
necessary to generate reports. 

RETURN JUMP - An instruction that jumps from a sequence of instructions to 
initiate a second sequence and prepares for continuing the first sequence 
after the second is completed. 

ROUTINE - The sequence of operations which the computer performs; also 
called a program. 

S REGISTER - The 13-bit S register displays the address of the storage word 
currently being referenced. 

SCALE FACTOR - One or more coefficients by which quantities are multiplied 
or divided so that they lie in a given range of magnitude. 

SCAN - Synonomous with Search. 

SEARCH - Searching a field of characters for a certain condition or a specific 
character. 

SHIFT - To move the bits of a quantity right or left. 
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SIGN BIT - In registers where a quantity is treated as signed by use of one's 
complement notation, the bit in the highest order stage of the register. If 
the bit is "l", the quantity is negative; if the bit is "O", the quantity is 
positive. 

SIGN CHARACTER - A unique character that indicates the algebraic sign (positive 
or negative) of a given field of characters. The upper two bits of a normal 
6 -bit character may be used or in some instances a specially formed 4-bit 
character exits. 

SIGN EXTENSION - The duplication of the sign bit in the higher order stages of 
a register. 

SOFTWARE - Programs and/or subroutines. 

SOURCE LANGUAGE - The language used by the programmer to define his 
program. 

STAGE - The FFs and inverters associated with a bit position of a register. 

STATUS - The state or condition of circuits within the processor, I/O channels, 
or external equipment. 

STORAGE CONTROL - The sequence of events within a particular storage 
module, controlling various internal storage operations. 

STORE - To transmit information to a device from which the unaltered infor- 
mation can later be obtained. The Store operation is essentially the re- 
verse of the Load operation. Storage location M is cleared, and the con- 
tents of the register are copied into M. 

SUBROUTINE - A set of instructions that is used at more than one point in 
program operation. 

SYMBOLIC CODING - A system of abbreviation used in preparing information 
for input into a computer; e.g.. Shift Q would be SHQ. (See Mnemonic) 

TOGGLE - To complement each specified bit of a quantity; i.e. , "l" to "O" or 
"0" to "1". 

TRANSMIT (Transfer) - The term transfer implies register contents are 

moved; i.e. , the contents of register 1 are copied into register 2. Unless 
specifically stated, the contents are not changed during transmission. The 
term transmit is often used synonymously with transfer. 

TWO'S COMPLEMENT - Number that results from subtracting each bit of a 

number from "O". The two's complement may be formed by complementing 
each bit of the given number and then adding one to the result, performing 
the required carries. 

UNDERFLOW - An illegal change of sign from - to +, e.g. , subtracting from a 
quantity so that the result would be less than - (2^-1), where n is the 
modulus. In floating point notation, this occurs where the value of the 
exponent becomes less than 2"10 + 1 (- ITTTg). 
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WORD - The content of a storage location; it can be an instruction or 24 bits of 
data. 

WRITE - To enter a quantity into a storage location. 

X REGISTER - An arithmetic transfer register, nonaddres sable and not 
displayed. 

Z REGISTER - A 28 -bit storage data register; receives the data and parity bits 
as they are read from storage or written into storage. Nonaddres sable but 
displayed on the 'T' panel in the storage module. 
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TABLE 1. OCTAL LISTING OF INSTRUCTIONS 



Basic 
Octal 
Code 


Mnemonic 
Code 


Address 
Field 


Instruction Description 


Page 
No. 


00 


HLT 


m 


Unconditional halt, RNI @ m on restarting 


5-24 


00 


SJl 


m 


If jump key 1 is set, jump to m 


5-41 


00 


SJ2 


m 


If jump key 2 is set, jump to m 


5-41 


00 


SJ3 


m 


If jump key 3 is set, jump to m 


5-41 


00 


SJ4 


m 


If jump key 4 is set, jump to m 


5-41 


00 


SJ5 


m 


If jump key 5 is set, jump to m 


5-41 


00 


SJ6 


m 


If jump key 6 is set, jump to m 


5-41 


00 


RTJ 


m 


P+1 -*m (address portion), RNI @ m+1, 
return to m for P+1 


5-47 


01 


UJPJ 


m,b 


Unconditional jump to m 


5-41 


02 


No Operatic 


)n 






02 


IJI 


ni,b 


If (B^) = 0,RNI @ P+1; if (B^) f 0, (B^) + 
1 -*Bb, RNI @ m 


5-43 


02 


No Operatic 


)n 






02 


IJD 


m,b 


If (B*^) = 0, RNI @ P+1; if (B^) f 0, (B*^) - 
1 -Bb, RNI @ m 


5-44 


03 


AZJ,EQ 


m 


If (A) = 0,RNI @ m, otherwise RNI @ P+1 


5-45 


03 


AZJ,NE 


m 


If (A) ?^ 0,RNI @ m, otherwise RNI @ P+1 


5-45 


03 


AZJ,GE 


m 


If (A) >0, RNI@ m, otherwise RNI @ P+1 


5-45 


03 


AZJ,LT 


m 


If (A) <0, RNI@m, otherwise RNI @ P+1 


5-45 


03 


AQJ.EQ 


m 


If (A) = (Q),RNI @ m, otherwise RNI® P+1 


5-46 


03 


AQJ^NE 


m 


If (A) f (Q),RN1 @ m, otherwise RNI @ P+1 


5-46 


03 


AQJ^GE 


m 


If (A) >(Q),RNI @ m, otherwise RNI@P+1 


5-46 


03 


AQJ,LT 


m 


If (A) <(Q),RNI @ m, otherwise RNI @ P+1 


5-46 


04 


ISE 


y 


If y = 0,RNI @ P+2, otherwise RNI @ P+1 


5-28 


04 


ISE 


y,b 


If y = (B^),RNI @ P+2, otherwise RNI @ P+1 


5-28 


04 


ASE,S 


y 


If y = (A), RNI @ P + 2, otherwise RNI @ 
P+1. Sign of y extended. 


5-29 


04 


QSE,S 


y 


If y = (Q), RNI @ P + 2, otherwise RNI @ 
P + 1. Sign of y extended. 


5-29 


04 


ASE 


y 


If y = (A), RNI @ P + 2, otherwise RNI @ 
P + 1. Lower 15 bits of A are used. 


5-29 


04 


QSE 


y 


If y = (Q), RNI @ P + 2, otherwise RNI @ 
P + 1. Lower 15 bits of Q are used. 


5-29 
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TABLE 1. OCTAL LISTING OF INSTRUCTIONS (Cont'd) 



Basic 


Mnemonic 


Address 


Instruction Description 


Page 


Octal 


Code 


Field 




No. 


Code 










05 


ISO 


y 


If y = 0, RNI @ P+2, otherwise RNI @P+1 


5-30 


05 


ISO 


y,b 


(Bb) > y, RNI @ P+2, otherwise RNI @ P+1 


5-30 


05 


ASG,S 


y 


If (A) >y, RNI @ P+2, otherwise RNI @ 
P+1. Sign of y is extended 


5-30 


05 


QSG,S 


y 


If (Q) >y. RNI @ P+2, otherwise RNI @ 
P+1. Sign of y is extended 


5-30 


05 


ASG 


y 


If (A) >y, RNI @ P+2, otherwise RNI @ P+1 


5-30 


05 


QSG 


y 


If (Q)>y,RNI @ P+2, otherwise RNI @ P+1 


5-30 


06 


MEQ 


ni,i 


(b1) - i -*b1; if (B^) negative, RNI @P+1; 
if (b1) positive, test (A) = (Q) A (M); if 
true, RNI @ P+2; if false, repeat sequence 


5-75 


07 


MTH 


m,i 


(B2)-i-B2; if (B^) negative RNI @ P+1; if 
(b2) positive, test (A) >(Q) A (M); if true, 
RNI @ P+2; if false, repeat sequence 


5-76 


10 


SSH 


m 


'Test sign of (m), shift left one place, end 
around, replace in storage. If sign neg- 
ative, RNI @P+2; otherwise RNI @ P+1 


5-57 


10 


ISI 


y.b 


If (B^)= y, clear B^ and RNI @ P+2; if 
(Bb) ?t y^ (Bb) + 1 ^bP, RNI @ P+1 


5-31 


10 


ISD 


y.b 


If (Bb) = y, clear B^ and RNI @ P+2; if 
(Bb) / y, (Bb) - 1 ^Bb, RNI @ P+1 










5-31 


11 


ECHA 


z 


z ->A, lower 17 bits of A are used 


5-26 


11 


ECHA,S 


z 


z -J-A, sign of z extended 


5-26 


12 


SHA 


k, b 


Shift (A). Shift count K=k+(B^) (signs of k 
and Bb extended. )If bit 23 of K="r', shift 


















right; complement of lower 6 bits equals 










shift magnitude. If bit 23 of K="0", shift 










left; lower 6 bits equals shift magnitude. 










Left shifts end around; right shifts end off. 


5-57 


12 


SHQ 


k,b 


Shift (Q). Shift count K=k+(Bb)( signs of k 
and Bb extended. If bit 23 of K="l", shift 
right; complement of lower 6 bits equals 
shift magnitude. If bit 23 of K="0", shift 
left;lower 6 bits equals shift magnitude. 
Left shifts end around; right shifts end off. 


5-59 


13 


SHAQ 


k,b 


Shift (AQ) as one register. Shift count K= 
k+(Bb) (signs of k and Bb extended). If 
bit 23 of K="l", shift right;complement of 
lower 6 bits equals shift magnitude. If bit 
23 of K="0", shift left;Iower 6 bits equal 
shift magnitude. Left shifts end around; 
right shifts end off. 


5-59 
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Basic 
Octal 
Code 


Mnemonic 
Code 


Address 
Field 


Instruction Description 


Page 
No. 


13 


SCAQ 


k, b 


Shift (AQ) left end around until upper 2 bits 
of A are unequal. Residue K = k - shift 
count. If b = 1,2, or 3, K -Bb; if b = 0, K 
is discarded. 


5-59 


14 


No Operation 


No operation (COMPASS assembled NOP) 




14 


ENI 


y,b 


Clear B , enter y 


5-25 


14 


ENA.S 


y 


Clear A, enter y, sign, of y extended 


5-25 


14 


ENQ,S 


y 


Clear Q, enter y, sign of y extended 


5-25 


14 


ENA 


y 


Clear A, enter y 


5-25 


14 


ENQ 


y 


Clear Q, enter y 


5-25 


15 


No Operation 






15 


INI 


y.b 


Increase (B ) by y, signs of y and B 
extended 


5-27 


15 


INA,S 


y 


Increase (A) by y, sign of y extended 


5-27 


15 


INQ.S 


y 


Increase (Q) by y, sign of y extended 


5-27 


15 


INA 


y 


Increase (A) by y 


5-27 


15 


INQ 


y 


Increase (Q) by y 


5-27 


16 


No Opera 


tion 






16 


XOI 


y,b 


yv(B'=)^B^ 


5-71 


16 


XOA,S 


y 


y V (A) -*A, sign of y extended 


5-71 


16 


XOQ.S 


y 


y V (Q) -^Q, sign of y extended 


5-71 


16 


XOA 


y 


y V (A) ->A 


5-71 


16 


XOQ 


y 


y V (Q) - Q 


5-71 


17 


No Operation 






17 


ANI 


y,b 


y A (B^)-B^ 


5-73 


17 


ANA,S 


y 


y A (A) -^A, sign of y extended 


5-73 


17 


ANQ,S 


y 


y A (Q) -*Q, sign of y extended 


5-74 


17 


ANA 


y 


y A (A) -A 


5-73 


17 


ANQ 


y 


y A (Q) - Q 


5-74 


20 


LDAJ 


m,b 


(M) -^A, 


5-49 


21 


LDQ.I 


m,b 


(M) -*Q 


5-51 


22 


LACH 


r,l 


(R) -*A. Load lower 6 bits of A 


5-49 


23 


LQCH 


r,2 


(R) -*Q. Load lower 6 bits of Q 


5-52 
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Basic 
Octal 
Code 


Mnemonic 
Code 


Address 
Field 


Instruction Description 


Page 
No. 


24 


.LCA,I 


m,b 


(M) ^A 


5-50 


25 


LDAQ,I 


ni,b 


(M) -A, (M + 1) -*Q 


5-50 


26 


LCAQJ 


in,b 


(M) ->A, (M + 1) ->Q 


5-51 


27 


LDL,I 


m,b 


(M) A (Q) -*A 


5-50 


30 


ADA, I 


m,b 


Add (M) to (A) ->A 


5-60 


31 


SBA,I 


m,b 


(A) minus (M) -*A 


5-61 


32 


ADAQ,I 


ni,b 


Add (M,M + 1) to (AQ) -^AQ 


5-61 


33 


SBAQJ 


m,b 


(AQ) minus (M,M + 1) -AQ 


5-61 


34 


RAD, I 


in,b 


Add (M) to (A) -^(M) 


5-60 


35 


SSA,I 


m,b 


Where (M) contains a "l" bit, set the cor- 
responding bit in A to "l" 


5-72 


36 


SCA,I 


ra,h 


Where (M) contains a "l" bit, complement 
the corresponding bit in A 


5-72 


37 


LPA,I 


ni,b 


(M) A (A) -A 


5-73 


40 


STA,I 


m,b 


(A) -*(M) 


5-53 


41 


STQ,I 


m,b 


(Q) -(M) 


5-55 


42 


SACH 


r,2 


(AoO-05) ->R 


5-54 


43 


SQCH 


r,l 


(QoO-05) -*R 


5-55 


44 


SWA, I 


ni,b 


(AOO-14) -*(M00-14) 


5-56 


45 


STAQ,I 


in,b 


(AQ) -*(M,M + 1) 


5-54 


46 


SCHA,I 


ni,b 


(Aoo-16) ^(MoO-16) 


5-56 


47 


STLI 


ni,b 


(B^)-(Moo-14) 


5-56 


50 


MUA,I 


nijb 


Multiply (A) by (M) -*QA; lowest order bits 
of product in A 


5-62 


51 


DVA,I 


m,b 


(AQ)-;- (M) -* A, remainder — Q 


5-62 


52 


CPR,I 


m,b 


(M) >(A), RNI @ P+1 1 ,.) , ,Q. 
(Q) >(M), RNI @ P+2 \ ^^^h^n^ed 
(A) >(M) > (Q), RNI @ P+3J unchanged 


5-77 


53 


TIA 


b 


Clear (A),(B^-^ Aoo-14 


5-33 


53 


TAI 


b 


(Aoo-14)--B^ 


5-33 


53 


TMQ 


V 


(v)-Q 


5-34 


53 


TQM 


V 


(Q)-^v 


5-34 


53 


TMA 


V 


(v)-A 


5-34 


53 


TAM 


V 


(A)-v 


5-34 
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Octal 
Code 


Mnemonic 
Code 


Address 
Field 


Instruction Description 


Page 
No. 


53 


TMI 


v,b 


(Voo-14)-^B^ 


5-35 


53 


TIM 


v,b 


(B^) - voo-14 


5-35 


53 


AQA 




Add (A) to (Q) ->A 


5-32 


53 


AIA 


b 


Add (A) to (B^) -*A 


5-33 


53 


lAI 


b 


Add (A) to (B^) -*B^. Sign of B^ extended 
prior to addition 

All other combinations of 53 are undefined 
and will be rejected by the assembler 


5-33 


54 


LDLI 


ni,b 


(Moo-14)-^B^ 


5-52 


55 


RIS 




Use (ISR) in address relocation for 
operands. RELOCATE TO INSTRUCTION 
STATE 


5-112 


55 


ELQ 




(El)-*Q 


5-36 


55 


EUA 




(Ey) -A 


5-36 


55 


EAQ 




(EuEl) -AQ 


5-36 


55 


ROS 




Use (OSR) in address relocation for 
operands. RELOCATE TO OPERAND 
STATE 


5-112 


55 


QEL 




(Q) -* Ej^ 


5-36 


55 


AEU 




(A)'>Ey 


5-36 


55 


AQE 




(AQ) -^E^El 


5-36 


56 


MUAQ,I 


m,b 


Multiply (AQ) by (M,M + 1) -^AQE 


5-63 


57 


DVAQ,I 


m,b 


(AQE) 4 (M,M + 1) -*AQ and remainder 
with sign extended to E. Divide fault halts 
operation and program advances to next 
instruction 


5-63 


60 


FAD, I 


m,b 


Floating point addition of (M,M + 1) to 
(AQ) -AQ 


5-65 


61 


FSB, I 


ni,b 


Floatingpoint subtraction of (M,M + 1) 
from (AQ) -*AQ 


5-65 


62 


FMU,I 


ni,b 


Floating point multiplication of (AQ) and 
(M,M + 1) -*AQ 


5-66 


63 


FDV,I 


ni,b 


Floating point division of (AQ) by (M,M 
+ 1) -*-AQ, remainder with sign extended 
to E 


5-66 


64 


MVE 


r, Bp, 

Si, s. 


Move characters from fid A —fid C ac- 
cording to parameters given 


5-140 
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Mnemonic 


Address 


Instruction Description 


Page 


Octal 


Code 


Field 




No. 


Code 










64 


MVE,DC 


r,Br, 
s,Bs, 


Move characters from fid A -*fld C 
according to parameters given. Delimiting 








S2 


character possibility 


5-141 


64 


MVBF 


r,Bp, 


Move characters from fid A ^fld C; if 








Si , s. 


fid C>fld A, blank fill 


5-142 






Bs. S2 






64 


MVZF 


r, B^, 


Move characters from fid A ^fld C; if 








Si, i. 


fid C >fld A, zero fill 


5-143 






Bs. S2 






64 


MVZS 


r, B^, 


Move characters from fid A ^fld C; sup- 








Si, s. 


press leading zeros 


5-144 






Bs, S2 






64 


MVZS,DC 


r, B^, 


Move characters from fid A -^fld C; sup- 
press leading zeros. Delimiting character 








S2 


possibility 


5-145 


64 


EDIT 


r, Br, 

Si, s. 


Fid A -*fld C with COBOL type of editing 
specified by picture previously stored in 








Bs. S2 


fid C 


5-149 


64 


FRMT 


r, B^, 

Si, s, 
Bg, Sg 


Fid A -* fid C with editing specified by 
picture previously stored in fid; limited 
to specific types of editing to allow pro- 








cessing in a single scan. 


5-147 


65 


SCAN, 


r, B^, 


Scans fid A from left to right, stop on = 






LR,EQ 


S2, sc 


condition 


5-129 


65 


SCAN, 


r, Br, 


Scans fid A from left to right, stop on = 






LR, EQ, 


S2. SC 


condition. Delimiting character possibility 


5-130 




DC 








65 


SCAN, 


r, Br, 


Scans fid A from right to left, stop on = 






RL,EQ 


S2. SC 


condition 


5-133 


65 


SCAN, 


r, Br, 


Scans fid A from right to left, stop on = 






RL, EQ, 


S2, SC 


condition. Delimiting character 


5-134 




DC 




possibility 




65 


SCAN, 


r, B^, 


Scans fid A from left to right, stop on 4 






LR,NE 


S2. SC 


condition 


5-131 


65 


SCAN, 


r,B 

S2,SC, 


Scan fid A from left to right, stop on j^ 






LR, NE 


condition. Delimiting character possibility 


5-132 




DC 








65 


SCAN, 


r, Br, 


Scans fid A from right to left, stop on / 






RL, NE 


S2,SC 


condition 


5-135 
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Mnemonic 


Address 


Instruction Description 


Page 


Octal 


Code 


Field 




No. 


Code 










65 


SCAN, RL, 


r,Br, 


Scans fid A from right to left, stop on 4: 






NE,DC 


S2,SC, 


condition. Delimiting character possibility 


5-136 


66 


CVDB 


r, B^, 

Si, m. 
Bra 


Convert BCD fid A to binary fid ^C 


5-115 


66 


CVBD 


m. Bin, 
n, Bn 


Convert binary fid A to BCD ^fld C 


5-116 


66 


DTA 


r, Br, 
S2, na, 

^m 


Translate BCD fid A to ASCH -*fld C 


5-117 


66 


DTA,DC 


r, Br, 


Translate BCD fid A to ASCII ^fld C with 








S2 ,m' 
B 


delimiting character possibility 


5-118 


66 


ATD 


m 
m, Bm, 
S2, s, 

Bs 


Translate ASCII fid A to BCD -*fld C 


5-119 


66 


ATD,DC 


m, Bm, 


Translate ASCII fid A to BCD -fid C with 








S2. s, 

Bq 


delimiting character possibility 


5-120 


66 


PAK 


r, Bj, 
S2, m. 


Pack 6-bit BCD fid A into 4-bit BCD fid C 


5-121 


66 


UPAK 


s,Bs, 
S2 


Unpack 4-bit BCD fid A into 6-bit BCD fid C 


5-122 


67 


ADM 


r, Br, 
Si, s, 

^s' ^2 


Add fid A to fid C -fid C 


5-68 


67 


SBM 


r, Br, 
Si, s, 
Bs' S2 


Subtract fid A from fid C -> fid C 


5-69 


67 


ZADM 


r, Br, 
Si, s, 
Bs» S2 


Clear fid C; fid A -fid C, right justify 


5-146 
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Basic 


Mnemonic 


Address 


Instruction Description 


Page 


Octal 


Code 


Field 




No. 


Code 










67 


CMP 


r, Br, 
Sl,s, 


Compares fid A to fid C, exits upon 
encountering 4 characters 


5-79 


67 


CMP, DC 


s •'2 

r, Br, 
s, Bg, 


Compares fid A to fid C, exits upon en- 
countering 4 characters; delimiting 








S2 


character possibility 


5-80 


67 


TST 


r, Br, 

h 


Test fid A, +, -, or 


5-82 


67 


TSTN 


r, B^, 
Si 


Test fid A for numeric 


5-82. 


70 


JMP, HI 


m 


Jump if BDP condition register > or + 


5-42 


70 


JMP, ZRO 


m 


Jump if BDP condition register = 


5-42 


70 


JMP, LOW 


m 


Jump if BDP condition register < or - 


5-42 


70 


LBR 


m 


Load BCR and restore BDP conditions 
from data at 'm' 


5-155 


70 


SBR 


m 


Store (BCR) and BDP conditions at 'm' 
for interrupt recovery. 


5-155 


71 


SRCE, 
INT 


SC, r, s 


Search for equality of scan character 
'SC'' in a field beginning at location r 
until an equal character is found, or 
until character location s is reached; 


5-125 


71 


SRCN, 


SC, r, s 


Same as SRCE except search condition is 






INT 




for inequality 


5-127 


72 


MOVE, 
INT 


S,r, s 


Move (S) characters from r to s 


5-138 


73 


INPC, INT 
B, H, G 


ch, r, s 


A 6- or 12-bit character is read from 
peripheral device and stored in memory 
at a given location 


5-98 


73 


INAC, 
INT 


ch 


(A) is cleared and a 6-bit character is 
transferred from a peripheral device to 
the lower 6 bits of A 


5-106 


74 


INPW, 


ch, m. 


Word address is placed in bits 00-14, 






INT, B, N, 


n 


12- or 24-bit words are read from a 






G 




peripheral device and stored in memory 


5-100 
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74 


INAW, 
INT 


ch 


(A) is cleared and a 12-or 24-bit word is 
read from a peripheral device into the lower 
12 bits or all of A (word size depends on 
I/O channel) 


5-107 


75 


OUTC, 
INT , B , H 


ch,r, s 


Storage words disassembled into 6- or 12- 
bit characters and sent to a peripheral 
device 


5-102 


75 


OTAC, 

INT 


ch 


Character from lower 6 bits of A is sent to 
a peripheral device, (A) retained 


5-109 


76 


OUTW, 

INT . B , N 


ch,m, n 


Words read from storage to a peripheral 
device 


5-104 


76 


OTAW, 
INT 


ch 


Word from lower 12 bits or all of A (de- 
pending on type of I/O channel) sent to a 
peripheral device 


5-110 


77 


CON 


x,ch 


If channel ch is busy, reject instruction 
RNl @ P + 1. If channel ch is not busy, 12- 
bit connect code sent on channel ch with 
connect enable, RNI @ P + 2 


5-95 


77 


SEL 


X, ch 


If channel ch is busy, read reject instruction 
from P + 1. If channel ch is not busy, a 
12 -bit function code is sent on channel ch 
with a function enable, RNI @ P + 2 


5-96 


77 


EXS 


X, ch 


Sense external status if "l" bits occur on 
status lines in any of the same positions as 
"1" bits in the mask, RNI @ P + 1. If no 
comparison, RNI @ P + 2 


5-83 


77 


COPY 


ch 


External status code from I/O channel ch -* 
lower 12 bits of A, contents of interrupt 
mask register -* upper 12 bits of A; RNI @ 
P + 1 


5-83 


77 


INS 


X, ch 


Sense internal status if "l" bits occur on 
status lines in any of the same positions as 
"1" bits in the mask, RNI @ P + 1. If no 
comparison, RNI @ P + 2 


5-85 


77 


cms 


ch 


Interrupt mask and internal status to A 


5-86 


77 


INTS 


X, ch 


Sense for interrupt condition: If "l" bits 
occur simultaneously in interrupt lines and 
in the interrupt m.ask, RNI @ P + 1; if not, 
RNI @ P + 2 


5-84 


77 


INCL 


X 


Interrupt faults defined by x are cleared 


5-89 
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77 


lOCL 


X 


Clears I/O channel or search/move control 
as defined by bits 00-07, 08, and 11 of x. 


5-94 


77 


CILO 


X 


Lockout external interrupt on masked 
channels (x), until channel(s) is not busy. 


5-91 


77 


CLCA 


X 


Clear the specified channel, but not external 
equipment. CLEAR CHANNEL ACTIVITY 


5-94 


77 


SSIM 


X 


Selectively set interrupt mask register for 
each "l" bit in x. The corresponding bit 
in the mask register is set to "l" 


5-90 


77 


SCIM 


X 


Selectively clear interrupt mask register 
for each "l" bit in x. The corresponding 
bit in the mask register is set to "O" 


5-90 


77 


A CI 




AOO-02 -^CIR 

A TO CHANNEL INDEX REGISTER 


5-38 


77 


CIA 




Clear A; Channel index register -*Aoo-02 


5-38 


77 


JAA 




Last executed jump address -*A 
JUMP ADDRESS TO A 


5-40 


77 


lAPR 




Interrupt associated processor 


5-113^ 


77 


PAUS 


X 


Sense busy lines. If "l" appears on a line 
corresponding to "l" bits in x, do not ad- 
vance P. If P is inhibited for longer than 
40 ms, read reject instruction from P + 1. 
If no comparison, RNI @ P + 2 


5-87 


77 


PRP 




Same as PAUS except real-time 

clock cannot increment during the pause 

PRIORITY PAUSE 


5-88 


77 


.TMAV 




Initiate memory request. If reply occurs 
within 5 usee, RNI @ P + 2; if not, RNI @ 
P + 1. Storage address is (B^) with (OSR) 
or zero appended. TEST MEMORY 
AVAILABILITY 


5-81 


77 


SBJP 




Transfers system from Monitor State to 
Program State when next jump instruction 
is executed. SET BOUNDARY JUMP 


5-112 


77 


SDL 




Causes next LDA instruction to: 

1. (M) -*A 

2. Store 77777777 @ M 
SET DESTRUCTIVE LOAD 


5-113^ 


77 


CRA 




Clear A; Condition register^ Aqq-qs 


5-40 , 


77 


ACR 




Aqo-OS "* Condition register 


5-40 

1 
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Page 


Octal 
Code 


Code 


Field 




No. 


77 


APF 


w, 2 


^00-11 *° P^s® ^^^^ 
A TO PAGE FILE 


5-39 


77 


PFA 


w, 2 


Clear A, page file index ^A„„ ^ ^ 
PAGE FILE TO A vv xi 


5-39 


77 


AOS 




^00-02 -*OSR 

A TO OPERAND STATE REGISTER 


5-37 


77 


AIS 




^00-02 ^ISR 

A TO INSTRUCTION STATE REGISTER 


5-37 


77 


OSA 




Clear A; OSR -*Aqq_q2 

OPERAND STATE REGISTER TO A 


5-37 


77 


ISA 




Clear A; ISR -*Aqq_q2 

INSTRUCTION STATE REGISTER TO A 


5-37 


77 


SLS 




Program stops if Selective Stop switch is 
on; upon restarting, RNI @ P + 1 


5-24 


77 


SFPF 




Set floating point fault logic 


5-91 


77 


SB CD 




Set BCD fault logic 


5-91 


77 


DINT 




Disables interrupt control 


5-89 


77 


EINT 




Interrupt control is enabled, allows one more 
instruction to be executed before interrupt 


5-89 


77 


CTI 




Set Type In 


Beginning character address 
must be preset in location 23 
. of register file and last 
character address + 1 must 
be preset in location 33 of 


5-97 


77 


CTO 




Set Type Out_ 


the file 




77 


UCS 




Unconditional stop. Upon restarting, RNI 
@ P + 1 


5-24 
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Instruction Description 
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AC I 


77 




AoO-02-* CIR 

A TO CHANNEL INDEX REGISTER 


5-38 


ACR 
ADA, I 


77 
30 


m, b 


Aqq.qc to Condition register 
Add (M) to (A)- A 


5-40 
5-60 


ADAQ, I 
ADM 


32 
67 


m, b 

r, Br, Si, 
s,B^,S2 


Add (M, M + 1) to (AQ) - AQ 
Add fid A to fid C - fid C 


5-61 
5-68 


AEU 


55 




(A)-Eu 


5-36 


AIA 


53 


b 


Add (A) to (Bt') -*A 


5-33 


AIS 


77 




A00-02-*ISR 

A TO INSTRUCTION STATE REGISTER 


5-3 7 


ANA 


17 


y 


yA (A) -A 


5-73 


ANA,S 


17 


y 


y A (A) ^A, sign of y extended 


5-73 


ANI 


17 


y.b 


y A (Bb) -Bb 


5-73 


ANQ 


17 


y 


y A (Q) -Q 


5-74 


ANQ,S 


17 


y 


y A (Q) -*Q, sign of y extended 


5-74 


AOS 


77 




Aoo-02 -*OSR 

A TO OPERAND STATE REGISTER 


5-37 


APF 


77 


w, 2 


AqO-II ^Page file 
A TO PAGE FILE 


5-39 


AQA 


53 




Add (A) to (Q) -A 


5-32 


AQE 


55 




(AQ) --EuEl 


5-36 


AQJ,EQ 


03 


m 


If (A) = (Q), RNI @ m, otherwise RNI @ 
P + 1 


5-46 


AQJ,GE 


03 


m 


If (A) >.(Q), RNI @ m, otherwise RNI @ 
P + 1 


5-46 


AQJ , LT 


03 


m 


If (A) <(Q), RNI @ m, otherwise RNI @ 
P + 1 


5-46 


AQJ,NE 


03 


m 


If (A) i^ (Q), RNI @ m, otherwise RNI @ 
P + 1 


5-46 


ASE 


04 


y 


If y = (A), RNI @ P + 2, otherwise RNI @ 
P + 1. Lower 15 bits of A are used. 


5-29 


ASE,S 


04 


y 


If y = (A), RNI @ P + 2, otherwise RNI @ 
P + 1 ^ sign of y is extended 


5-29 


ASG 


05 


y 


If (A) >y, RNI @ P + 2, otherwise RNI @ 
P + 1 


5-30 
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Mnemonic 
Code 



ASG,S 
ATD 

ATD,DC 

AZJ,EQ 
AZJ^GE 
AZJ,LT 

AZ J , NE 

CIA 
CILO 

CINS 
CLCA 

CMP 

CMP, DC 
CON 

COPY 

CPR.I 
CRA 



Basic 
Octal 
Code 



05 
66 

66 

03 

03 

03 

03 

77 
77 

77 
77 

67 

67 

77 

77 

52 

77 



Address 
Field 



m3m^ 

Bs 

m,Bm. 

Bs 
m 



m 
m 
m 

X 

ch 

X 



r,Br, 
Si, s, 
Bs, S2 

r, Br, 

s, Bg 

S2 
X, ch 



ch 



ni,b 



Instruction Description 



If (A) >y, RNI @ P + 2, otherwise RNI @ 
P + 1, sign of y is extended 

Translate ASCII fid A to BCD -> fid C 



Translate ASCII fid to BCD ->fld C with 
delimiting character possibility 

If (A) = 0, RNI @ m, otherwise RNI @ 

P + 1 

If (A) >0, RNI @ m, otherwise RNI @ 

P + 1 

If (A) <0, RNI @ m, otherwise RNI @ 

P + 1 

If (A) f 0, RNI @ m, otherwise RNI @ 

P + 1 

Clear A; Channel index register -*Aoo-02 

Lockout external interrupt on masked 
channels (x), until channel(s) is not busy 

Interrupt mask and internal status to A 

Clear the specified channel, but not ex- 
ternal equipment. CLEAR CHANNEL 
ACTIVITY 

Compares fid A to fid C, exits upon en- 
countering i" characters 

Compares fid A to fid C, exits upon en- 
countering i= characters; delimiting 
character possibility 

If channel ch is busy, reject instruction, 
RNI @ P+1. If channel ch is not busy, 
12 -bit connect code sent on channel ch 
with connect enable, RNI @ P+2. 
External status code from I/O channel ch 
to lower 12 -bits of A, contents of inter- 
rupt mask register to upper 12-bits of 
A RNI @ P+1 

(M) >(A), RNI @ P+1 1 (A) and (Q) 

(Q) > (M), RNI @ P + 2 t-are 

(A) >.(M) >(Q), RNI @ P+3J unchanged 

Condition register to Aoo-05 



Page 
No. 



5-30 
5-119 



5-120 



5- 


45 


5- 


45 


5- 


45 


5- 


■45 


5- 


-38 


5- 


-91 


5- 


-86 


5- 


-94 


5 


-79 



5-80 
5-95 

5-83 

5-77 
5-40 
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Mnemonic 
Code 
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Octal 
Code 


Address 
Field 


Instruction Description 


Page 
No. 


CTI 
CTO 


77 
77 




Set Type In ~ 
Set Type Out , 


Beginning character ad- 
dress must be preset in 
location 2 3 of register 
file and last character ad- 
dress + 1 m.ust be preset 
in location 33 of the file 


5-97 


CVBD 


66 


r, Br, 

m,B^ 


Convert binary fid A to BCD ->fld C 


5-116 


CVDB 


66 


m,Bm, 
Si, s, 
Bs 


Convert BCD fid A to binary ^fld C 


5-115 


DINT 


77 




Disables interrupt control 


5-89 


DTA 


66 


r,Br, 

S2,m, 

Bm 


Translate BCD fid A to ASCII -fid C 


5-117 


DTA,DC 


66 


r, Br, 

S2 '"!' 


Translate BCD fid A to ASCII -fid C with 
delimiting character possibility 


5-118 


DVA,I 


51 


m,b 


{AQ)h- (M) -* A, remainder - Q 


5-62 


DVAQ,I 


57 


m,b 


(AQE)-=- (M,M + 1) -*AQ and remainder with 
sign extended to E. Divide fault halts op- 
eration and program advances to next 
instruction 


5-63 


EAQ 


55 




(EuEL) -*AQ 


5-36 


ECHA 


11 


z 


z —A, lower 17 bits of A are used 


5-26 


ECHA,.S 


11 


z 


z — A, sign of z extended 


5-26 


EDIT 


64 


r, Br, 
Si, s, 
Bs' S2 


Fid A -ofld C with COBOL type of editing 
specified by picture previously stored in 
fid C 


5-149 


EINT 


77 




Interrupt control is enabled. Allows one 
more instruction to be executed before 
interrupt 


5-89 


ELQ 


55 




(El) ->q 


5-36 


ENA 


14 


y 


Clear A, enter y 


5-25 


ENA,S 


14 


y 


Clear A, enter y, sign of y extended 


5-25 


ENI 


14 


y,b 


Clear B", enter y 


5-25 


ENQ 


14 


y 


Clear Q, enter y 


5-25 
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Basic 
Octal 
Code 
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Instruction Description 


Page 

No. 


ENQ,S 


14 


y 


Clear Q, enter y, sign of y extended 


5-25 


EUA 
EXS 

FAD, I 


55 

77 

60 


x,ch 
ni,b 


(Ey) -A 

Sense external status if "l" bits occur on 

status lines in any of the same positions 

as "1" bits in the mask, RNI @ P+1. If 

no comparison RNI @ P+2. 

Floating point addition of (M,M + 1) to 

(AQ) -AQ 


5-36 

5-83 
5-65 


FDV,I 


63 


m,b 


Floating point division of (AQ) by (M,M + 
1) -*AQ, Remainder with sign extended to 
E. 


5-66 


FMU,I 


62 


in,b 


Floating point multiplication of (AQ) and 
(M,M + 1) -^AQ 


5-66 


FRMT 


64 


r,Br, 
Si ,s, 
Bs.S2 


Fid A -* fid C with editing specified by 
picture previously stored in fid; linaited to 
specific types of editing to allow pro- 
cessing in a single scan. 


5-147 


FSB, I 


61 


m,b 


Floating point subtraction of (M,M + 1) 
from (AQ) -AQ 


5-65 


HLT 


00 


m 


Unconditional halt, RNI @m upon re- 
starting 


5-24 


lAI 


53 


b 


Add (A) to (B^") - B^. Sign of B^ extended 
prior to addition 


5-33 


lAPR 


77 




Interrupt associated processor 


5-113 


IJD 


02 


in,b 


If (B^) = 0, RNI @ P + 1; if (B^) f 0, (B^) 
- 1 -B^, RNI @ m 


5-44 


IJI 


02 


in,b 


If (B^) = 0, RNI @ P + 1; if (B^) f 0, (B^) 
+ 1 -*B°. RNI @ m 


5-43 


INA 


15 


y 


Increase (A) by y 


5-27 


INA,S 


15 


y 


Increase (A) by y, sign of y extended 


5-27 


INAC, 
INT 


73 


ch 


(A) is cleared and a 6-bit character is 
transferred from a peripheral device to 
the lower 6 bits of A 


5-106 


INAW, 
INT 


74 


eh 


(A) is cleared and a 12- or 24-bit word is 
read from a peripheral device into the 
lower 12 bits or all of A (word size depends 
on I/O channel) 


5-107 


INCL 


77 


X 


Interrupt faults defined by x are cleared 


5-89 


INI 


15 


y,b 


Increase (B ) by y, signs of y and B° 
extended 


5-27 
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TABLE 2. ALPHAMNEMONIC LISTING OF INSTRUCTIONS (Cont'd) 



Mnemonic 
Code 


Basic 
Octal 
Code 


Address 
Field 


Instruction Description 


Page 
No. 


'INPC, 
INT^B, 
H,G 


73 


ch,r, s 


A 6- or 12 -bit character is read from a 
peripheral device and stored in memory 
at a given location 


5-98 


INPW, 
INT , B , 
N,G 


74 


ch,m, 
n 


Word Address is placed in bits 00-14, 12- 
or 24-bit words are read from a peri- 
pheral device and stored in memory 


5-100 


INQ 


15 


y 


Increase (Q) by y 


5-27 


INQ,S 


15 


y 


Increase (Q) by y, sign of y extended 


5-27 


INS 


77 


x,ch 


Sense internal status if "l" bits occur on 
status lines in any of the same positions 
as "1" bits in the mask, RNI @ P + 1. 
If no comparison, RNI @ P + 2 


5-85 


INTS 


77 


c,ch 


Sense for interrupt condition; if "l" bits 
occur simultaneously in interrupt lines 
and in the interrupt mask, RNI @ P + 1; 
if not, RNI @ P + 2 


5-84 


lOCL 


77 


X 


Clears I/O channel or search/move con- 
trol as defined by bits 00-07, 08, and 11 
of X. 


5-94 


ISA 


77 




Clear A, ISR -*Aoo-02 

INSTRUCTION STATE REGISTER TO A 


5-37 


ISD 


10 


y,b 


If (Bb) = y, clear B^ and RNI @ P + 2; 
if (Bb) f y, (Bb) - 1 ^Bb, RNI @ P + 1 


5-31 


ISE 


04 


y 


If y = 0, RNI @ P+2, otherwise RNI @ 
P + 1 


5-28 


ISE 


04 


y,b 


If y = (B^), RNI @ P + 2, otherwise RNI 
@ P+ 1 


5-28 


ISG 


05 


y 


If y = 0, RNI @ P + 2, otherwise RNI @ 
P + 1 


5-30 


ISO 


05 


y.b 


If (B^) >y, RNI @ P + 2, otherwise ROT 
@ P + 1 


5-30 


ISI 


10 


y.b 


If (Bb) = y, clear B^ and RNI @ P + 2; if 
(B°) f y, (Bb) + 1 -Bb, RNI @ P + 1 


5-31 


JAA 


77 




Last executed jump address -"-A 
JUMP ADDRESS TO A 


5-40 


JMP, HI 


70 


m 


Jump if BDP condition register >0 or + 


5-42 


JMP, 
LOW 


70 


m 


Jump if BDP condition register < or - 


5-42 


JMP, 
ZRO 


70 


m 


Jump if BDP condition register = 


5-42 
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TABLE 2. ALPHAMNEMONIC LISTING OF INSTRUCTIONS (Cont'd) 



Mnemonic 
Code 


Basic 
Octal 
Code 


Address 
Field 


Instruction Description 


Page 
No. 


LACH 


22 


r, 1 


(R) -*A; load lower 6 bits of A 


5-49 


LBR 


70 


m 


Load BCR and restore BDP conditions 
from data at 'm' 


5-155 


LCA.I 
LCAQ.I 


24 
26 


m.b 
m,b 


(M) -A 


5-50 
5-51 


(M) -A. (M + 1) ->Q 


LDA.I 


20 


m.b 


(M) -A 


5-49 


LDAQ.I 


25 


m.b 


(M) -A. (M + 1) -*Q 


5-50 


LDI.I 


54 


m.b 


(Moo-i4)--B^ 


5-52 


LDL.I 


27 


m.b 


(M) A (Q) -*A 


5-50 


LDQ.I 


21 


m,b 


(M) -^Q 


5-51 


LPA.I 


37 


in,b 


(M) A (A) -»A 


5-73 


LQCH 


23 


r.2 


(R) -^Q; load lower 6 bits of Q 


5-52 


MEQ 


06 


m.i 


(B^) - i -^B^; if (B^) negative. RNI @ 
P + 1; if (rI) positive, test (A) = (Q) A 
(M); if true. RNI @ P + 2, if false, repeat 
sequence 


5-75 


MOVE, 
INT 


72 


S.r.s 


Move (S) characters from r to s 


5-138 


MTH 


07 


in,i 


(b2) - i. -h-b^. if (B^) negative. RNI @ P + 
1; if (b2) positive, test (A) >(Q) A (M); 
if true, RNI @ P + 2; if false, repeat se- 
quence 


5-76 


MUA.I 


50 


m,b 


Multiply (A) by (M) -*QA; lowest order 
bits of product in A 


5-62 


MUAQ.I 


56 


m.b 


Multiply (AQ) by (M.M + 1) ->AQE 


5-63 


MVBF 


64 


r,B^, 

Si. s, 
Bs^ S2 


Move characters from fid A -*fld C; if 
fid C > f Id A . blank fill 


5-142 


MVE 


64 


r. B^. 
Si. s 
Bs. S2 


Move characters from fid A -^ fid C ac- 
cording to parameters given 


5-140 


MVE,DC 


64 


r. B^. 
s. Bg, 

S2 


Move characters from fid A -*fld C ac- 
cording to parameters given. Delimiting 
character possibility 


5-141 


MVZF 


64 


r. Br. 
Si. s, 
Bs. S2 


Move characters from fid A -*fld C; if 
fid C >fld A, zero fill 


5-143 
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TABLE 2. ALPHAMNEMONIC LISTING OF INSTRUCTIONS (Cont'd) 



Mnemonic 
Code 



MVZS 



MVZS,DC 



OSA 

OTAC, 

INT 

OTAW, 
INT 

OUTC, 
INT , B , 
H 

OUTW, 
INT,B,N 

PAK 



PAUS 



PFA 


77 


PRP 


77 


QEL 


55 


QSE 


04 


QSE,S 


04 


QSG 


05 


QSG,S 


05 



Basic 
Octal 
Code 



Address 
Field 



64 

64 

77 
75 
76 

75 

76 
66 

77 



^1- 



LJJ.J 



Bs^ ^2 

r, Br. 
s, Bg, 

S2 



ch 



Instruction Description 



Move characters from fid A- 
suppress leading zeros 



•fid C; 



ch 



ch, r , s 



ch,m,n 

r-,Br,S2 
m, B^ 



Move characters from fid A ^ fid C; sup- 
press leading zeros. Delimiting character 
possibility 

Clear A; OSR -*Aoo-02 

OPERAND STATE REGISTER TO A 

Character from lower 6 bits of A is sent 
to peripheral device ,(A) retained 

Word from lower 12 bits or all of A 
(depending on type of I/O channel) sent to 
a peripheral device 

Storage words disassembled into 6 or 12- 
bit characters and sent to a peripheral de- 
vice 

Words read from storage to peripheral 

device 

Pack 6-bit BCD fid A into 6-bit BCD 

fid C 

Sense busy lines. If "l" appears on a line 
corresponding to "l" bits in x, do not ad- 
vance P. If P is inhibited for longer than 
40 ms, read reject instruction from P + 1. 
If no comparison, RNI @ P + 2 

Clear A, page file index -^Aqo-H 
PAGE FILE TO A 

Same as PAUS except real time clock 
cannot increment during the pause 
PRIORITY PAUSE 

(Q) -El 

If y = (Q), RNI @ P + 2, otherwise RNI @ 
P + 1; lower 15 bits of Q are used 

If y = (Q). RNI @ P + 2, otherwise RNI @ 
P + 1, sign of y is extended 

If (Q) >y, RNI @ P + 2, otherwise RNI @ 
P + 1 

If (Q) >y, RNI @ P + 2, otherwise RNI @ 
P + 1, sign of y is extended 



Page 
No. 



5-144 

5-145 

5-37 

5-109 

5-110 

5-102 
5-104 
5-121 



5-87 
5-39 

5-88 
5-36 

5-29 

5-29 

5-30 

5-30 
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TABLE 2. ALPHAMNEMONIC LISTING OF INSTRUCTIONS (Cont'd) 



Mnemonic 
Code 


Basic 
Octal 
Code 


Address 
Field 


Instruction Description 


Page 

No. 


RAD J 


34 


m,b 


Add (M) to (A) -(M) 


5-60 


RIS 


55 




Use (ISR) in address relocation for operands 
RELOCATE TO INSTRUCTION STATE 


5-112 


ROS 


55 




Use (OSR) in address relocation for op- 
erands. RELOCATE TO OPERAND STATE 


5-112 


RTJ 


00 


m 


P + 1 -*M (address portion) RNI @ m + 1, 
return to m for P + 1 


5-47 


SACH 


42 


r,2 


(^00-05) -^R 


5-54 


SBA,I 


31 


m,b 


(A) minus (M) ^A 


5-61 


SBAQ,I 


33 


m,b 


(AQ) minus (M,M + 1) -^AQ 


5-61 


SBCD 


77 




Set BCD fault logic 


5-91 


SBJP 


77 




Transfers system from Monitor State to 
Program State when next jump instruction 
is executed. SET BOUNDRY JUMP 


5-112 


SBM 


67 


r, Br, 
Sl,s, 

Bs^ S2 


Subtract fid A from fid C -> fid C 


5-69 










SBR 


70 


m 


Store (BCR) and BDP conditions at 'm' for 
interrupt recovery 


5-115 


SCA, I 


36 


m, b 


Where (M) contains a "l" bit, complement 
the corresponding bit in A 


5-72 


SCAN, LR, 
EQ,DC 


65 


r, Br, 
S2, SC 


Scans fid A from left to right, stop on = 
condition. Delimiting character possibility 


5-130 


SCAN,LR 
NE, DC 


65 


r,Br,.S2 
SC 


Scans fid A from left to right, stop on i= 
condition. Delimiting character possibility 


5-132 


SCAN.RI^ 
EQ, DC 


65 


r, Br, 
S2, SC 


Scans fid A from right to left, stop on = 
condition. Delimiting character possibility 


5-134 


SCAN.RL, 
NE, DC 


65 


r, Br, 
S2, SC 


Scans fid A from right to left, stop on -J^ 
condition. Delimiting character possibility 


5-136 


SCAN, LR, 
EQ 


65 


r, Br, 
S2, SC 


Scans fid A from left to right, stop on = 
condition 


5-129 


SCAN, LR, 

NE 


65 


r, Br, 
S2,SC 


Scans fid A from left to right, stop on f 
condition 


5-131 
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TABLE 2. ALPHAMNEMONIC LISTING OF INSTRUCTIONS (Cont'd) 



Mnemonic 
Code 


Basic 
Octal 
Code 


Address 
Field 


Instruction Description 


Page 

No. 


SCAN, 
RL, EQ 


65 


r, Br, 
S2, SC 


Scans fid A from right to left, stop on = 
condition 


5-133 


SCAN, 
RL, NE 


65 


r, B^, 
S2,SC 


Scans fid A from right to left, stop on i= 
condition 


5-135 


SCAQ 


13 


k, b 


Shift (AQ) left end around until upper 2 bits 
of A are unequal. Residue K = k shift count. 
If b = 1, 2, or 3 , K - B*^; if b = , K is 
discarded 


5-59 


SCHA,I 


46 


m^b 


(AoO-16) -*(Moo-16) 


5-56 


SCIM 


77 


X 


Selectively clear Interrupt Mask Register for 
each "l" bit in x. The corresponding bit in 
the naask register is set to "O". 


5-90 


SDL 


77 




Causes next LDA instruction to: 

1. (M) -A 

2. Store 77777777 @ M 
SET DESTRUCTIVE LOAD 


5-113 


SEL 


77 


x,ch 


If channel ch is busy, read reject instruction 
from P + 1. If channel ch is not busy, a 12- 
bit function code is sent on channel ch with 
a function enable RNI @ P + 2 


5-96 


SFPF 


77 




Set floating point fault logic 


5-91 


SHA 


12 


k, b 


Shift (A). Shift count K=k + (B^) (signs of k 
and BO extended). If bit 23 of K="l", shift 
right; complement of lower 6 bits equals 
shift magnitude. If bit 23 of K = "O", shift 
left; lower 6 bits equal shift magnitude. 
Left shifts end around; right shifts end off 


5-57 


SHAQ 


13 


k, b 


Shift (AQ) as one register. Shift count K = k 
+ fib (signs of k and B^ extended). If bit 2 3 
of K = "l", shift right and complement of 
lower 6 bits equals shift magnitude. If bit 23 
of K = "0", shift left and lower 6 bits equal 
shiftrnagnitude. Left shifts end around; 
right shifts end off 


5-59 


SHQ 


12 


k,b 


Shift (Q), Shift count K=k + (B^) (signs of k 
and W^ extended). If bit 23 of K = "l", shift 
right, complement of lower 6 bits equals 
shift magnitude. If bit 23 of K = "O", shift 
left, lower 6 bits equal shift magnitude. 
Left shifts end around; right shifts end off 


5-59 
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Mnemonic 
Code 



Basic 
Octal 
Code 



Address 
Field 



Instruction Description 



Page 
No. 



SJl 
SJ2 
SJ3 
SJ4 
SJ5 
SJ6 
SLS 

SQCH 



SRCE, 

INT 



SRCN, 
INT 

SSAJ 
SSH 

SSIM 

STA,I 

STAQ,I 

STI,I 

STQ,I 

SWA, I 

TAI 

TAM 

TIA 

TIM 

TMA 



00 
00 
00 
00 
00 
00 
77 

43 
71 



71 
35 
10 

77 

40 
45 
47 
41 
44 
53 
53 
53 
53 
53 



m 
m 
m 
m 
m 
m 



r,l 



SC,r,s 

SC,r,s 

m,b 

m 



m,b 
m,b 
nijb 
m,b 
m^b 
b 

V 

b 
v,b 

V 



E jump key 1 is set, jump to m 

If jump key 2 is set, jump to m 

If jump key 3 is set, jump to m 

If jump key 4 is set, jump to m 

If jump key 5 is set, jump to m 

If jump key 6 is set, jump to m 

Program stops if Selective Stop switch is on; 
upon restarting RNI @ P + 1 

(^00-05^ ^^ 



Search for equality of scan character SC in 
a field beginning at location r until an equal 
character is found, or until character loca- 
tion s is reached. 

Same as SRCE except search condition is 
for inequality 

Where (M) contains a "l" bit, set the cor- 
responding bit in A to "l" 

Test sign of (m), shift (m) left one place, 
end around and replace in storage. If sign 
negative, RNI @ P + 2; otherwise RNI @ 
P + 1 

Selectively set interrupt mask register for 
each "l" bit in x. The corresponding bit in 
the mask register is set to "l" 

(A) ->(M) 

(AQ) -*(M, M + 1) 

(Bb)->(Moo-14) 
(Q) --(M) 

(^00-14)^(^00-14) 

(^00-14) -^Bb 

(A) ->v 

Clear (A), (B^) -Aqo-m 

(B^)- 

(v) -^A 



^00-14 



5-41 
5-41 
5-41 
5-41 
5-41 
5-41 

5-24 
5-55 



5-125 
5-127 
5-72 

5-57 

5-90 
5-53 
5-54 
5-56 
5-55 
5-56 
5-33 
5-34 
5-33 
5-35 
5-34 
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Mnemonic 
Code 


Basic 
Octal 
Code 


Address 
Field 


Instruction Description 


Page 
No. 


TMAV 


77 




Initiate memory request. If reply occurs 
within 5 usee, RNI at P + 2; if not, RNI at 
P + 1. Storage address is (b2) with (OSR) 
or zero appended. TEST MEMORY 
AVAILABILITY 


5-81 


TMI 


53 




^00-14)-Bb 


5-35 


TMQ 


53 


V 


(v) ->Q 


5-34 


TQM 


53 


V 


(Q) -- V 


5-34 


TST 


67 


r, B 
Si 


Test fid A, +, -, or 


5-82 


TSTN 


67 


•'1 
r, Br, Si 


Test fid A for numeric 


5-82. 


UCS 


77 




Unconditional stop. Upon restarting RNI @ 
P+ 1 


5-24 


UJP, I 


01 


rci, b 


Unconditional jump to M. 


5-41 


UPAK 


66 


m,B^, 
s,Bs,S2 


Unpack 4-bit BCD fid A into 6-bit BCD 
fid C 


5-122 


XOA 


16 


y 


y V (A) -A, 


5-71 


XOA,S 


16 


y 


y V (A) -*A, sign of y extended 


5-71 


XOI 


16 


y.b 


y V (Bb)^B^ 


5-71 


XOQ 


16 


y 


y V (Q) -^ Q 


5-71 


XOQ,S 


16 


y 


y V (Q) -*Q, sign of y extended 


5-71 


ZADM 


67 


r, Br, 
Si, s, 
Bs» S2 


Clear fid C; fid A -*fld C, right justify 


5-146 
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Function 


Mnemonic 
Code 


Instruction Description 


Page 
No. 


Arithmetic 


ADA, I 


Add (M) to (A) -*A 


5-60 




ADAQJ 


Add (M,M + 1) to (AQ) --AQ 


5-61 




AIA 


Add (A) to (Bb) -A 


5-33 




ADM 


Add fid A to fid C ->fld C 


5-68 




AQA 


Add (A) to (Q) -A 


5-32 




AQE 


(AQ) -(EuEl) 


5-36 




DVA.I 


(AQ)-i- (M) -^ A, Remainder -* Q 


5-62 




DVAQ, I 


(AQE)-r (M,M + 1) -*AQ and remainder with 
sign extended to E. Divide fault halts 
operation and program advances to next 
instruction 


5-63 




FAD, I 


Floating point addition of (M,M + 1) to (AQ) 
-AQ 


5-65 




FDV,I 


Floating point division of (AQ) by (M,M + 1) 
-*AQ, remainder with sign extended to E 


5-66 




FMU,I 


Floating point multiplication of (AQ) and 
(M,M + 1) — AQ 


5-66 




FSB, I 


Floating point subtraction of (M,M + 1) 
from (AQ) — AQ 


5-65 




lAI 


Add (A) to (B^) -^B^. Sign of b'^ extended 
prior to addition 


5-33 




INA 


Increase (A) by y 


5-27 




INA,S 


Increase (A) by y, sign extended 


5-27 




INI 


Increase (B^) by y, signs of y and B are 
extended 


5-27 




INQ 


Increase (Q) by y 


5-27 




INQ,S 


Increase (Q) by y, sign extended 


5-27 




MUA,I 


Multiply (M) by (A) -*QA. Lowest order 
bits of product in A 


5-62 




MUAQ,I 


Multiply (AQ) by (M,M + 1) -*AQE 


5-63 




RAD, I 


Add (M) to (A) -*(M) 


5-60 




SBA,I 


(A) minus (M) -*A 


5-61 




SBAQ,I 


(AQ) minus (M,M + 1) -*AQ 


5-61 




SBM 


Subtract fid A from fid C -fid C 


5-69 
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Function 


Mnemonic 
Code 


Instruction Description 


Page 
No. 


Character 
Operation 


ATD 


Translate ASCII fid A to BCD -fid C 


5-119 




ATD,DC 


Translate ASCH fid A to BCD -*fld C with 
delimiting character possibility 


5-120 




CMP 


Compares fid A to fid C, exits upon en- 
countering f characters 


5-79 




CMP, DC 


Compares fid A to fid C, exits upon en- 
countering f characters; delimiting char- 
acter possibility 


5-80 




CVBD 


Convert binary fid A to BCD -*fld C 


5-116 




CVDB 


Convert BCD fid A to binary -*fld C 


5-115 




DTA 


Translate BCD fid A to ASCII -*fld C 


5-117 




DTA,DC 


Translate BCD fid A to ASCII -*fld C with 
delimiting character possibility 


5-118 




ECHA 


z -*Aoo-l6 


5-26 




ECHA,S 


z -*A sign extended 


5-26 




EDIT 


Fid A -*fld C with COBOL type of editing 
specified by picture previously stored in 
fid C 


5-149 




FRMT 


Fid A -*fld C with editing specified by pic- 
ture previously stored in fid; limited to 
specific types of editing to allow processing 
in a single scan. 


5-147 




LACH 


(R)-Aoo-05 


5-49 




LQCH 


(R)-*Q00-05 


5-52 




MVBF 


Move characters from fid A -*fld C; if fid 
C >fld A, blank fill 


5-142 




MOVE, 
INT 


Move S characters from r to s 


5-138 




MVE 


Move characters from fid A -*fld C ac- 
cording to parameters given 


5-140 




MVE,DC 


Move characters from fid A -*fld C 
according to parameters given. Delimiting 
character possibility 


5-141 




MVZF 


Move characters from fid A -*fld C; if 
fid Ofld A, zero fill 


5-143 
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Function 



Character 
Operation 
(Cont'd) 



Decision 



Mnemonic 
Code 



MVZS 
MVZS,DC 

PAK 

SACK 

SCAN.LR, 
EQ, DC 

SCAN,LR, 
NE, DC 

SCAN,RL, 
EQ, DC 

SCAN,RL, 
NE, DC 

SCAN,LR, 
EQ 

SCAN, LR 

NE 

SCAN,RL, 
EQ 

SCAN,RL, 

NE 

SCHA,I 

SQCH 

UPAK 

ZADM 
AQJ,EQ 
AQJ.GE 
AQJ,LT 
AQJ , NE 



Instruction Description 



Page 
No. 



Move characters from fid A -*fld C; 
suppress leading zeros 

Move characters from fid A ^fld C; 
suppress leading zeros. Delimiting 
character possibility 

Pack 6-bit BCD fid A into 4-bit BCD fid C 



(A 



0-R 



00-05 

Scans fid A from left to right, stop on = 
condition. Delimiting character possibility 

Scans fid A from left to right, stop on ?^ 
condition. Delimiting character possibility 

Scans fid A from right to left, stop on = 
condition. Delimiting character possibility 

Scans fid A from right to left, stop on f 
condition. Delimiting character possibility 

Scans fid A from left to right, stop on = 
condition. 

Scans fid A from left to right, stop on f 
condition 

Scans fid A from right to left, stop on = 
condition 

Scans fid A from right to left, stop on f 
condition 

(AoO-16)^(]^00-16) 

(Qoo-05>-^<R) 

Unpack 4-bit BCD fid A into 6-bit BCD 
fid C 

Clear fid C; fid A -*fld C, right justify 
If (A) = (Q),RNI @ m, otherwise RNI@P+1 
If (A) >(Q),RNI@m, otherwise RNI@P+1 
If (A) < (Q) , RNI @ m , otherwise RNI @ P+1 
If (A) f (Q), RNI@ m, otherwise RNI @ P+1 



5-144 

5-145 
5-121 

5-54 

5-130 

5-132 

5-134 

5-136 

5-129 

5-131 
5-133 

5-135 
5-56 
5-55 
5-122 

5-146 

5-46 

5-46 

5-46 

5-46 



__ 
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TABLE 3. FUNCTION LISTING OF INSTRUCTIONS (Cont'd) 



Function 


Mnemonic 
Code 


Instruction Description 


Page 
No. 


Decision 
(Cont'd) 


ASE 


If y = (A), RNI @ P + 2, otherwise RNI @ ■ 
P + 1. Lower 15 bits of A are used 


5-29 




ASE.S 


If y = (A), RNI @ P + 2, otherwise RNI @ 
P + 1. Sign of y is extended 


5-29 




ASG 


If (A) >y, RNI @ P + 2, otherwise @ P+ 1 


5-30 




ASG.S 


If (A) >y, RNI @ P + 2, otherwise RNI @ 
P + 1. Sign of y is extended 


5-30 




AZJ,EQ 


If (A) = 0, RNI @ m, otherwise RNI @ P+1 


5-45 




AZJ,GE 


If (A) >0, RNI @ m, otherwise RNI @ P+1 


5-45 




AZJ,LT 


If (A) <0, RNI @ m, otherwise RNI @ P+1 


5-45 




AZJ^NE 


If (A) M, RNI @ m, otherwise RNI @ P+1 


5-45 




CPR,I 


(M)>(M) RNI@P+l1 /A^ & fO) are 
(Q) > (M) RNI® P + 2 ^ InchanJed 
(A)>(M)>(Q) RNI@P+3j unchanged 


5-77 




IJD 


If (B^) = 0, RNI @ P+1; if (B^^) f 0, (B^) - 1 
- Bb , RNI @ m 


5-44 




IJI 


If (B^) = 0, RNI @ P+1; if (B^) f 0, (B^) + 1 
-*Bb, RNI @ m 


5-43 




ISD 


If (B^) = y, clear B*^ and RNI @ P + 2; if B^ 
# y, (Bb) - 1 -*Bb, RNI @ P + 1 


5-31 




ISE 


If y = 0, RNI @ P+2, otherwise RNI @ 
P + 1 


5-28 




ISE 


If y = {-b!°), RNI @ P+2, otherwise RNI @ 
P+1 


5-28 




ISG 


If y = 0, RNI @P+2, otherwise RNI @ 
P+1 


5-30 




ISG 


If (B^) >y, RNI @ P+2, otherwise RNI @ 
P + 1 


5-30 




ISI 


If (B^) = y, clear b'^ and RNI @ P+2; if 
(B^) f y, (B*^) + 1 -Bb, RNI @ P+1 


5-31 




SRCE,INT 


Search for equality of scan character SC in 
a field beginning at location r until equal 
character is found, or until character lo- 
cation s is reached 


5-125 




SRCN,INT 


Same as SRCE except search condition is 
for inequality 


5-127 




SSH 


Test sign of (xn), shift (m) left one place 
end around and replace in storage. If 
sign negative, RNI @ P+2; otherwise RNI 
@ P+1 


5-57 
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TABLE 3. FUNCTION LISTING OF INSTRUCTIONS (Cont'd) 



Function 



Mnemonic 
Code 



Instruction Description 



Page 
No. 



Decision 
(Cont'd) 



MEQ 



MTH 



PAUS 



Executive 
Mode 



PRP 

QSE 

QSE,S 

QSG 
QSG,S 

TST 
ACI 

ACR 

AIS 

AOS 

APF 

CIA 
CRA 

ISA 

JAA 
OSA 

PFA 



(b1) - i -pl; if (b1) negative, RNI @ P+1; 
if (pl) positive, test (A) >(Q) A (M), if true 
RNI @ P+2, if false, repeat sequence 

(B2)-i ^(b2); if (b2) negative, RNI @ P+1; 
if (b2) positive, test (A) > (Q) A (M); if 
true, RNI @ P+2; if false, repeat sequence 

Sense busy lines. If "l" appears on a line 
corresponding to "l" bits in x, do not ad- 
vance P. If P is inhibited for longer than 
40 ms, read reject instruction from P+1. 
If no conaparison, RNI @ P+2 

Same as PAUS except real-time clock can- 
not increment during the pause 
PRIORITY PAUSE 

If y = (Q), RNI @ P+2.; otherwise RNI @ 
P+1. Lower 15 bits of Q are used 

If y = (Q), RNI @ P+2; otherwise RNI @ 
P+1. Sign of y is extended 

If (Q) >y, RNI @ P+2; otherwise RNI @ P+1 

If (Q) >y. RNI @ P+2; otherwise RNI @ 
P+1. Sign of y is extended 

Test fid A, +, -, or 

AoO-02^CIR 

A TO CHANNEL INDEX REGISTER 

^00-05-^ C^ 

A TO CONDITION REGISTER 

^00-02 ~* ISR 

A TO INSTRUCTION STATE REGISTER 



A, 



00-02 



OSR 



A TO OPERAND STATE REGISTER 

A-OO-ll-* page file 
A TO PAGE FILE 

Clear A; channel index register -* ^nn^no 
Clear A; condition register"^ ^00-05 
Clear A; ISR -* A, 



5-75 



5-76 



INSTRUCTION STAT 



P^^ 



Last executed jump address 
JUMP ADDRESS TO A 



REGISTER TO A 
A 



Clear A; OSR- 



^00-02 



OPERAND STATE REGISTER TO A 
Clear A, page file index -^ A^ 



PAGE FILE TO A 



00-11 



5-87 

5-88 

5-29 

5-29 
5-30 

5-30 
5-82 

5-38 

5-40 

5-37 

5-37 

5-39 
5-38 
5-40 

5-37 

5-40 

5-37 

5-39 
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TABLE 3. FUNCTION LISTING OF INSTRUCTIONS (Cont'd) 



Function 


Mnemonic 
Code 


Instruction Description 


Page 
No. 


Executive 








Mode (Cont'd) 


RIS 


Use (ISR) in address relocation for 
operands. RELOCATE TO INSTRUCTION 
STATE 


5-112 




ROS 


Use (OSR) in address relocation for 
operands. RELOCATE TO OPERAND 
STATE 


5-112 




SBJP 


Transfers system from Monitor State to 
Program State when next jump instruction 
is executed. SET BOUNDARY JUMP 


5-112 




SDL 


Causes next LDA instruction to: 

1. (M)^A 

2. Store 77777777 @ M 
SET DESTRUCTIVE LOAD 


5-113 




TMAV 


Initiate memory request. If reply occurs 
within 5 usee, RNI @ P+2: if not, RNI @ 
P+1. Storage address is (B2) with (OSR) 
or zero appended 
TEST MEMORY AVAILABILITY 


5-81 


Input/ Output 


CLCA 


Clear the specified channel, but not 
external equipment. CLEAR CHANNEL 
ACTIVITY 


5-94 




CON 


If channel ch is busy, read reject instruc- 
tion from P+1. If channel ch is not busy, 
12 -bit connect code sent on channel ch with 
connect enable, RNI @ P+2 


5-95 




COPY 


External status code from I/O channel ch 
to lower 12 -bits of A, contents of interrupt 
mask register to upper 12-bits of A. RNI 
@ P+1 


5-83 




CTI 
CTO 


Set Type In 
Set Type Out^ 


Beginning character address 
must be preset in location 
> 23 of register file and last 
character address + 1 must 
be preset in location 33 of 
the file. 


5-97 




EXS 


Sense external status if "l" bits occur on 
status lines in any of the same positions 
as "1" bits in the mask, RNI @ P+1. If no 
comparison, RNI @ P + 2. 


5-83 
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TABLE 3. FUNCTION LISTING OF INSTRUCTIONS (Cont'd) 



Function 


Mnemonic 
Code 


Instruction Description 


Page 
No. 


Input/ Output 
(Cont'd) 


INACJNT 


(A) is cleared and a 6-bit character is 
transferred from a peripheral device to the 
lower 6 bits of A 


5-106 




INAWJNT 


(A) is cleared and a 12 or 24-bit word is 
read from a peripheral device into the 
lower 12 bits or all of A (Word size de- 
pends on I/O channel) 


5-107 




INPCJNT 
B,H,G 


A 6 or 12-bit character is read from peri- 
pheral device and stored in memory at a 
given location 


5-98 




INPWJNT, 
B,N,G 


Word address is placed in bits 00-14; 12- 
or 24 -bit words are read from a peripheral 
device and stored in mem.ory 


5-100 




lOCL 


Clears I/O channel or search/move control 
as defined by bits 00-03, 08, and 11 of x. 
Bits 04-07, 09,and 10 are not used 


5-94 




OTACJNT 


Character from lower 6 bits is sent to 
peripheral device, (A) retained 


5-109 




OTAW, 
INT 


Word from lower 12 bits or all of A (de- 
pending on type of I/O channel) sent to a 
peripheral device 


5-110 




OUTC, 
INT,B,H 


Storage words asserabled into 6 or 12 -bit 
characters and sent to a peripheral device 


5-102 




OUTW, 
INT,B,N 


Words read from storage to peripheral 
device 


5-104 




SEL 


If channel ch is busy, read reject instruc- 
tion from P + 1. If channel ch is not busy, 
a 12 -bit function code is sent on channel 
ch with a function enable, RNI @ P+2 


5-96 


Interrupt 


CILO 


Lockout external interrupt on masked 
channels (x), until channel(s) is not busy. 


5-91 




CINS 


Interrupt mask and internal status to A 


5-86 




DINT 


Disable interrupt control 


5-89 




EINT 


Interrupt control is enabled, allows one 
more instruction to be executed before 
interrupt occurs 


5-89 




lAPR 


Interrupt associated processor 


5-113 




INCL 


Interrupt faults defined by x are cleared 


5-89 




INS 


Sense internal status if "l" bits occur on 
status lines in any of the same positions as 
"1" bits in the mask, RNI @ P + 1. If no 
comparison, RNI @ P+2. 


5-85 
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TABLE 3. FUNCTION LISTING OF INSTRUCTIONS (Cont'd) 



Function 


Mnemonic 
Code 


Instruction Description 


Page 
No. 


Interrupt 
(Cont'd) 


INTS 


Sense for interrupt condition; if "l" bits 
occur simultaneously in interrupt lines 
and in the interrupt mask, RNI @ P+1; if 
not, RNI @ P+2 


5-84 




LBR 


Load BCR and restore BDP conditions from 
data at 'm' 


5-155 




SBR 


Store (BCR) and BDP conditions at 'm' for 
interrupt recovery 


5-155 




SBCD 


Set BCD fault logic 


5-91 




SCIM 


Selectively clear interrupt mask register 
for each "l" bit in x. The corresponding 
bit in the mask register is set to "O". 


5-90 




SFPF 


Set floating point fault logic 


5-91 




SSIM 


Selectively set Interrupt mask register, for 
each "l" bit in x. The corresponding bit 
in the mask register set to "l". 


5-90 


Jumps and 


HLT 


Unconditional halt; RNI @ m upon restarting 


5-24 


Stops 


JMP,HI 


Jump if BDP condition register >0 or + 


5-42 




JMP.LOW 


Jump if BDP condition register < or - 


5-42 




JMP.ZRO 


Jump if BDP condition register = 


5-42 




RTJ 


P+1 -*m (address portion), RNI @ m+1, 
return to m for P+1 


5-47 




SJl 


If jump key 1 is set, jump to m 


5-41 




SJ2 


If jump key 2 is set, jump to m 


5-41 




SJ3 


If jump key 3 is set, jump to m 


5-41 




SJ4 


If jump key 4 is set, jump to m 


5-41 




SJ5 


If jump key 5 is set, jump to m 


5-41 




SJ6 


If jump key 6 is set, jump to m 


5-41 




SLS 


Program stops if Selective Stop switch is 
on; upon restarting, RNI @ P+1 


5-24 




UCS 


Unconditional stop. Upon restarting, RNI 
@ P+1 


5-24 




UJPJ 


Unconditional jump to m 


5-41 
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TABLE 3. FUNCTION LISTING OF INSTRUCTIONS (Cont'd) 



Function 


Mnemonic 


Instruction Description 


Page 




Code 




No. 


Logical 


ANA 


y A (A) - A 


5-73 


Operations 


ANA, S 


y A (A) -► A, sign of y extended 


5-73 




ANI 


y A (B^) - b"^ 


5-73 




ANQ 


y A (Q) ^ Q 


5-74, 




ANQ, S 


y A (Q) -♦ Q, sign of y extended 


5-74 




LDL, I 


(M) A (Q) -* A 


5-50 




LPA, I 


^(M) A (A) -* A 


5-73 




SCA, I 


Where (M) contains a "l", complement 








the corresponding bit in A 


5-72 




SSA, I 


Where (M) contains a "l" bit, set the 








corresponding bit in A to "l" 


5-72 




XOA 


y V (A) - A 


5-71 




XOA, S 


y V (A) -► A, sign of y extended 


5-71 




XOI 


y V (B^) -. Bb 


5-71 




XOQ 


y V (Q) -* Q 


5-71 




XOQ, S 


y V (Q) '* Q, sign of y extended 


5-71 


Shifts 


SCAQ 


Shift (AQ) left end around until upper 2 bits 
of A are unequal. Residue K =k- shift 
count. If b= 1, 2, or 3, K -* B°; if b = 0, K 








is discarded 


5-59 




SHA 


Shift- (A). Shift count K=k+(Bt') (signs of k 
and BD extended). If bit 23 of K="l", shift 














right; complement of lower 6 bits equals 
shift magnitude. If bit 23 of K = "0'\ shift 














left; lower 6 bits equal shift magnitude. 








Left shifts end around; right shifts end off 


5-57 




SHAQ 


Shift (AQ) as one register. Shift count K = 
k + (B^) (signs of k and B° extended). If 
bit 23 of K = "1", shift right; complement 
of lower 6 bits equals shift magnitude. If 
bit 23 of K = "0", shift left; lower 6 bits 
equal shift magnitude. Left shifts end 








around; right shifts end off 


5-59 




SHQ 


Shift (Q). Shift count K = k + (B^) (signs of 
k and B^ extended). If bit 23 of K = "l". 














shift right; complement of lower 6 bits 








equals shift magnitude. If bit 23 of K = "O", 








shift left; lower 6 bits equal shift magnitude. 








Left shifts end around; right shifts end off 


5-59 
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TABLE 3. FUNCTION LISTING OF INSTRUCTIONS (Cont'd) 



Function 


Mnemonic 
Code 


Instruction Description 


Page 

No. 


Shifts 
(Cont'd) 


SSH 


Test sign of (m), shift (m) left one place, 
end around and replace in storage. If sign 
negative, RNI@P+2; otherwise RNI @ 
P+1 


5-57 


Transfers 


AEU 


(A) - Ey 


5-36 




EAQ 


(E.y E^) -* AQ 


5-36 




ELQ 


(E^)- Q 


5-36 




ENA 


Clear A, enter y 


5-25 




ENA, S 


Clear A, enter y, sign extended 


5-25 




ENI 


Clear B , enter y 


5-25 




ENQ 


Clear Q, enter y 


5-25 




ENQ, S 


Clear Q, enter y, sign extended 


5-25 




EUA 


(Ey) - A 


5-36 




LCA, I* 
LCAQ, I* 


(M)- A 


5-50 
5-51 


(M)-> A, (M+ 1)-* Q 




LDA, I 


(M) ^ A 


5-49 




LDAQ, I 


(M) -A, (M + 1) - Q 


5-50 




LDI, I 


(Moo-l4)-B^ 


5-52 




LDQ, I 


(M)- Q 


5-51 




MOVE, 
INT 


Move S characters from r to s 


5-138 




QEL 


(Q) -* El 


5-36 




STA, I 


(A) -* (M) 


5-53 




STAQ, I 


(AQ) - (M, M + 1) 


5-54 




STI, I 


(B^)- (Moo- 14) 


5-56 




STQ, I 


(Q) -* (M) 


5-55 




SWA, I 

TAI 

TAM 


(^00-14)-* (Moo-14) 
(Aoo-i4)-Bb 

(A)- V 


5-56 
5-33 
5-34 




TIA 


Clear (A). {^^) ^ A00-14 


5-33 




TIM 


(Bb)->voo-i4 


5-35 



* Requires additional operation prior to transfer. 
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TABLE 3. FUNCTION LISTING OF INSTRUCTIONS (Cont'd) 



Function 


Mnemonic 
Code 


Instruction Description 


Page 
No. 


Transfers 
(Cont'd) 


TMA 
TMI 
TMQ 
TQM 


(v)- A 

(voo-14)-* B 
(v)- Q 

(Q)- V 


5-34 
5-35 
5-34 
5-34 
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INDEX 



A register, 1-5 

display, 7-1, 7-2 

manual entry, 7-12 
Access keyboard, 7-2, 7-9, 7-10 
Accumnaulator, see A register 
Active Digit indicator, 7-2 
Adapt, 6-6, 6-8 
Address modification, 5-6 

examples, 5-9 
Addressing, 2-5 

character, 5-4, 5-5 

conversion, 5-5 

Direct, 5-7 

Indirect, 5-8, 5-9 

modes, 2-4, 2-5, 5-7 

relocation, E-3 

word, 5-4, 5-5 

see also Indexing, Address Modification 
ALGOL, 6-3 

Applications software, 6-6 
Arithmetic, 

BCD, F-4 

functions, F-4 

interrupt, 4-2, 4-8 

Overflow fault, 4-2 

Reference information, B-1 

register, see A register 
ASCI], F-3 

conversion table. A- 3 
Associated Processor interrupt, 4-3, 4-7, 4- 
Auto Dump, 3-7, 4-4 

address protection, 2-6 

execution, 7-16 

switch description, 7-7 
Auto Load, 3-7, 4-4 

address protection, 2-6 

execution, 7-16 

switch description, 7-7 



Backgrounding, 6-2 
B registers, 1-6, 5-6 

display, 7-1, 7-2 
BCD, F-3 

conversion table. A- 3 

fault, 4-2 

internal, external codes, A-1 

word and character format, F-5 
BCR, see Business Data Processor Condition register 
Binary number system, B- 1 
Block control, 1-9, 2-8, 7-19 

priority, 1-10 

scanning pattern, 1-11 
Breakpoint switch, 1-9, 7-11 

examples, 7-17, 7-18 
Business Data Processor, 

Condition register, 1-14, 5-3 

description, 1-4 

instruction forrriat, 5-6 

instruction list, 1- 13 

Mode switch, 7-8 

trapped instructions, 4-6 



C register, 1-6 

display, 7-1, 7-2 
CR, see Condition register 
Central Processor Unit (CPU), 1-3 

internal organization, 1-5 

operation in Executive Mode, 1-9 

module location, 1-2 
Channel, see Input /Output 
Channel Index register, 1-7, 5-3 
Character addressing, 5-4, 5-5 

designators, 1-5 

modes, 2-4, 2-5 

set, A-1 
CIR, see Channel Index register 
COBOL, 1-1, 6-3, 6-4 
Coefficient, B-8 
COMPASS, 6-3, 6-4, 6-5 
Condition register, 5-3 
Connect, 3-4, 3-5, 5-95.0, 5-95.1 
Console, 1-4, 7-1 
Constants, C-4, C-5 
Conversion tables, 

BCD/ASCII, A-3 

Octal-Decimal Integer, C-6 

Octal-Decimal Fraction, C- 10 
Conversions, 

address, 5-5 

Fixed Point /Floating Point, B-13 

procedure, B-5 



DC, see delimiting character 
Data, 

bus, 1-8, 7-19, 7-22 

Bus register, 1-8 

entry, 7-2 

Interchange Display, 7-4 

processing, F- 1 

Processing Package, 6-3, 6-5 
Decimal/Binary position table, C-2 
Decimal/Octal conversion, 

procedures, B-5 

table, C-6 
Delimiting, 1-4, F- 1 

character, 5-2, 5-6 
Divide fault, 4-2 

interrupt code, 4- 10 

priority, 4-8 
Division, 

binary, B-4 

Floatingpoint, B-9 
Double Precision Arithmetic, B-8 



E Bit, see Exclusion bit 
E register, 1-6, 4-2, 7-10 
Emiergency Off switch, 7-1, 
Exclusion bit, 4-4, E-10 
Executive Mode, 1-7 
addressing, 2-5 
description, 1-9 
interrupt, 4-1, 4-3 



7-9, 7-12 



Index- 1 
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Monitor state, E-1, E-6 
Program State, E-1, E-6 
switch, 7-7 
Exponent, 

Fault, 4-2, 4-8, 4-10, B-13 
floating point, B-9 



F register, 1-7, 1-9 

display, 7-1, 7-2 
Fixed Point Arithmetic, B-8 
Floating Point, 

arithmetic, B- 9 

fault, 4-2, 4-8, 4-10, B-13 

module, 1-4 

E register, 1-6 
FORTRAN, 6-3 
Function, 3-4, 3-5, 5-96.0, 5-96.1 

codes, see instruction 



Trapped, 5-11 
Interface signals, 3-3, 7-8 

parity, 1-13 
Internal organization, 1-5 
Interrupt, 

clearing, 4-9 

codes, 4-10 

conditions, 4-2 

lines, 3-3 

Mask register, 4-10, 4-11 

priority, 4-8 

processing, 4-9, 4-10 

sensing, 4-9 

system information, 4- 1 



Jump, 

switches, 7-7 
see instructions 



ISR, see Instruction State register 
Illegal Write, 2-5 

indicator, 7-6 

interrupt, 4-1, 4-4, 4-5, 4-6, E-10 
Indexing, 
" examples, 5-9 

see address modification 
Index registers, 1-6, 1-14, 5-2, 5-6, 5-7 
Indirect Addressing, 

parameters, 5-1 

also see addressing 
Input /Output, 

channels, 3-1, 3-4 

disk, 6-2 

interface signals, 3-3 

interrupts, 4-1, 4-3 

modules, 1-3 

parity, 1-12, 1-13, 3-4 

software, 6-5 

system description, 3-1, 3-2 
Instruction State register, 1-7, 2-5 

display, 7-1, 7-3 
Instructions, 5-1 

Arithmetic, 5-60 

Character Search, 5-124 

Condition Test, 5-81 

Conversion, 5-114 

Enter, 5-25 

execution times, 5-19 

formats, 5-4, 5-8, D-1 

Halt and Stop, 5-24 

Increase, 5-27 

Input /Output, 5-92 

Inter- Register Transfer, 5-32 

Interrupt, 5-89 

Jximp, 5-41 

list (BDP), 1-13 

Load, 5-49 

Logical, 5-70 

Masked Search and Compare, 5-75 

Move, 5-137 

Mxiltiprocessing Control, 5-113 

No- Operation, 5-18 

parameters, 5-1 

Pause, 5-87 

Relocation Control, 5 

Sensing, 5-83 

Shift and Scale, 5-57 

Skip, 5-28 

Store, 5-53 

synopsis and index, 5 



-112 



■12 



Languages, 6-3, 6-4, 6-5 
Last Jump Address switch. 
Library tape, 6-1, 6-2 
Loudspeaker, 7-12 



7-8 



2-3 
2-5 

4-1, 4-4, 4-5, E-1 



MCS, see storage 

MSIO, 1-1, 6-6 

MSOS, 6-1, 6-2 

Main Control, 1-6, 2-8 

Manual Interrupt, 4- 1 

Mass Storage COBOL, 6-3, 6-4 

Mass Storage SORT, 6-6, 6-7 

MASTER, 1-1, 6-1, 6-2 

Meters, 

elapsed time, 7-24 

storage control. 
Modules, 1-2, 1-3, 
Modulus, B-1 
Monitor State, 1-9, 

indicator, 7-5 
Multiplication, 

binary, B- 4 

fixed point, B-8 

floating point, B-9 
Multiprogramming, 1- 1 

module, 1-2, 1-4, 2-5, E-1 



No- Operation instructions, 4-6, 5-l£ 

Non-Executive Mode, 1-9, 2-5, 3-7, 
description, 1-9 
trapped instructions, 4-5 

Normalizing, B- 13 

Number Systems, B-1 



OSR, see Operand State register 
Octal arithmetic matrices, C-3 
Octal number system, B-2 
Operand State register, 1-7 

application, E-2, E-4, E-5 

display, 7-3 
Operating systems, 6-1, 6-2 
Overflow fault, 4-2, B-13 



4-4 



P register, 1-6, 2-5 
display, 7-1, 7-2 

PIF, see Page Index File 

Page, 

Index File, E-7 
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Index registers, E-7 

Length (PL), E-12 

memory, 2-5, E-3 

Partial (PP) , E-12 

structure, E-3 

Zero, E-14 
Param.eters, see instructions 
Parity, 1-12 

Error indicator, 7-4, 7-6 

Error interrupt, 4-1, 4-4, 

Error signal, 3-5 

Interrupt switch, 7-7 

I/O, 1-13, 3-4, 3-5, 3-6 

storage, 1-12, 2-4 

Stop switch, 7-7 
Peripheral equipment, 1-14 
PERT, 6-6, 6-7 
Power Control Panel, 1-5 
Powerfail interrupt, 4-1, 4-7 
Program, 

Address Group, E-3 

protection, 2-7 

State, see Monitor State 



Q register, 1-5 

display, 7-1, 7-2 



4-5, 4-6 



S register, 1-8, 2-1 

SCOPE 

Real-Time, 6-1, 6-2 

Utility Routines, 6-1, 6-2 
Search, F-3 
Search/Move interrupt, 4-3 

codes, 4-10 

priority, 4-8 
SIPP, 6-6 
Software, 6-1 
SORT, 6-6 
Stacked jobs, 6-2 
Status, display, 7-1, 7-4 
Storage, 2-1 

access switches, 7-11 

addressing, 2-5 

Control panel, 2-2 

modules, 1-3, 2-1 

module photographs, 2-2, 2-3 

parity, 1-12 

parity error, 4-4 

protection, 2-5 

registers, 1-8, 2-1 

sharing, 2-8 

word, 2-4 
Switches, see console 



REGINA-I, 6-6, 6-7 

Radix, B-1 

Read next instruction (RNI), 5-11 

Real-Time Clock, 1-10, 1-11, 1-12 

interrupt, 4-3, 4-8, 4-10 
Real-Time SCOPE, 6-1, 6-2 
Register File, 7-19 

Assignments, 1-10 

breakpoint operation, 7-12, 7-17 

description, 1-9 
Registers, 

abbreviations, 5-3 

description, 1-5 
Relocation, 2-5, 3-7, E-1 
Report Generator, 6-3, 6-5 
RESPOND /MSOS, 6-6 
Rounding, B-12 



Time-Sharing, 1-1, 6-2, E-1 
Trapped instructions, 4-6, 5-11 

interrupts, 4-6, 4-7 
Typewriter, 7-1, 7-19 

codes, 7-23 

control switches, 7-19, 7-21 



Underflow fault, 4-2, B-13 



Word Addressing, see Addressing 
Word format, 1-5 
Write, 3-4, 3-5 



Z register, 1-8, 2-1 



S bus, 1-8, 2-5 
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QUICK REFERENCE INSTRUCTION INDEX 



Instruction Category 

NO-OPERATION 

HALT and STOP 

ENTER 

INCREASE 

SKIP 

INTER-REGISTER TRANSFER 

JUMPS 

LOAD 

STORE 

SHIFT and SCALE 

ARITHMETIC 

LOGICAL 

SEARCH 

COMPARE 

TEST 

SENSING 

PAUSE 

INTERRUPT 

INPUT /OUTPUT 

RELOCATION CONTROL 

MULTI-PROCESSING CONTROL 

CONVERSION 

MOVE 



Applicable Pages 

5-19 

5-24 

5-25 through 5-26 

5-27 

5-28 through 5-31 

5-32 through 5-40 

5-41 through 5-48 

5-49 through 5-52 and 5-155 

5-53 through 5-56 and 5-155 

5-57 through 5-59 

5-60 through 5-69 

5-70 through 5-74 

5-75, 5-76, and 5-124 through 5-136 

5-75 through 5-80 

5-81 through 5-82 

5-83 through 5-86 

5-87 through 5-88 

5-89 through 5-91 

5-92 through 5-111 

5-112 

5-113 

5-114 through 5-136 

5-137 through 5-154 



ADDITIONAL INSTRUCTION INFORMATION 



Instruction Parameters 

Register and Function Abbreviations 

Execution Time Table 

Octal Instruction Listing 

Alphamnemonic Instruction Listing 

Instruction Function Listing 

Trapped Instruction Listing 



5-1 through 5-3 

5-3 

5-19 

Instruction Tables 1 through 11 

Instruction Tables 12 through 22 

Instruction Tables 23 through 33 

4-5 
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